/* ═══════════════════════════════════════════════════════════════
   novo-design.css — Cosméticos New Connect
   Sistema de design moderno 2026
   Sobrepõe o main.css / Bootstrap 3 com uma camada visual premium.
═══════════════════════════════════════════════════════════════ */

/* ── 1. TOKENS / VARIÁVEIS ──────────────────────────────────── */
:root {
  --nc-primary:       #3D1235;
  --nc-primary-dark:  #2a0c24;
  --nc-primary-light: #f4e9f2;
  --nc-primary-rgb:   61, 18, 53;
  --nc-accent:        #c87eb5;
  --nc-accent-dark:   #9b4f8a;
  --nc-success:       #2f9e44;
  --nc-warning:       #f59f00;
  --nc-danger:        #c92a2a;
  --nc-info:          #1971c2;
  --nc-text:          #1e1b20;
  --nc-text-muted:    #6c6575;
  --nc-border:        #e8e0ec;
  --nc-bg:            #fafafa;
  --nc-card-bg:       #ffffff;
  --nc-shadow-sm:     0 1px 4px rgba(61,18,53,.08);
  --nc-shadow:        0 4px 16px rgba(61,18,53,.12);
  --nc-shadow-lg:     0 8px 32px rgba(61,18,53,.16);
  --nc-radius:        10px;
  --nc-radius-sm:     6px;
  --nc-radius-lg:     16px;
  --nc-font:          'Poppins', 'Roboto', sans-serif;
  --nc-transition:    all .22s ease;
}

/* ── 2. RESET & BASE ────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--nc-font) !important;
  font-size: 14px;
  color: var(--nc-text);
  background: var(--nc-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1,h2,h3,h4,h5,h6 {
  font-family: var(--nc-font) !important;
  font-weight: 600;
  color: var(--nc-text);
}

a { color: var(--nc-primary); transition: var(--nc-transition); }
a:hover { color: var(--nc-accent-dark); text-decoration: none; }

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

/* ── 3. ANNOUNCEMENT BAR ────────────────────────────────────── */
.nc-announce {
  background: var(--nc-primary);
  color: #fff;
  text-align: center;
  font-size: 12.5px;
  font-weight: 500;
  padding: 9px 16px;
  letter-spacing: .3px;
}
.nc-announce a { color: var(--nc-accent); }
.nc-announce a:hover { color: #fff; }

/* ── 4. HEADER ──────────────────────────────────────────────── */
.nc-header {
  background: #fff;
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: var(--nc-shadow);
}
/* Remove old header styles */
#header { all: unset; display: block; }
.header_top, .header-middle, .header-bottom { all: unset; display: none !important; }

.nc-header-main {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 20px;
  padding: 12px 0;
}
.nc-logo { display: flex; align-items: center; }
.nc-logo img {
  height: 44px;
  width: auto;
  object-fit: contain;
  filter: brightness(0) saturate(100%) invert(9%) sepia(54%) saturate(1385%) hue-rotate(285deg) brightness(90%);
}

/* Search */
.nc-search-form {
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
  position: relative;
}
.nc-search-form input {
  width: 100%;
  height: 40px;
  border: 1.5px solid var(--nc-border);
  border-radius: 20px;
  padding: 0 44px 0 16px;
  font-size: 13px;
  font-family: var(--nc-font);
  background: var(--nc-bg);
  color: var(--nc-text);
  outline: none;
  transition: var(--nc-transition);
}
.nc-search-form input:focus {
  border-color: var(--nc-accent);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(200,126,181,.15);
}
.nc-search-form button {
  position: absolute;
  right: 4px; top: 4px;
  width: 32px; height: 32px;
  border: none;
  background: var(--nc-primary);
  color: #fff;
  border-radius: 50%;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  transition: var(--nc-transition);
}
.nc-search-form button:hover { background: var(--nc-accent-dark); }

/* Actions (cart, WA, account) */
.nc-header-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.nc-action-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 6px 10px;
  border-radius: var(--nc-radius-sm);
  color: var(--nc-text-muted);
  font-size: 10.5px;
  font-weight: 500;
  text-decoration: none;
  transition: var(--nc-transition);
  white-space: nowrap;
}
.nc-action-link:hover {
  background: var(--nc-primary-light);
  color: var(--nc-primary);
  text-decoration: none;
}
.nc-action-link i { font-size: 20px; line-height: 1; }
.nc-action-link svg { display: block; }

/* Carrinho — mesmo layout, destaque via cor primária */
.nc-action-link.nc-cart {
  position: relative;
  color: var(--nc-primary);
  font-weight: 700;
  font-size: 10.5px;
  background: transparent;
  border-radius: var(--nc-radius-sm);
  padding: 6px 10px;
  flex-direction: column;
  gap: 3px;
}
.nc-action-link.nc-cart:hover {
  background: var(--nc-primary-light);
  color: var(--nc-primary);
}
.nc-action-link.nc-cart i { font-size: 20px; }

/* Nav */
.nc-nav {
  border-top: 1px solid var(--nc-border);
  background: #fff;
}
.nc-nav .container { position: relative; }
.nc-menu {
  display: flex;
  align-items: center;
  list-style: none;
  margin: 0; padding: 0;
  gap: 0;
}
.nc-menu > li > a {
  display: block;
  padding: 12px 16px 12px 0;
  font-size: 13px;
  font-weight: 500;
  color: var(--nc-text);
  text-decoration: none;
  transition: var(--nc-transition);
  position: relative;
}
.nc-menu > li > a::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 16px;
  height: 2px;
  background: var(--nc-primary);
  transform: scaleX(0);
  transition: transform .2s;
}
.nc-menu > li:hover > a,
.nc-menu > li.active > a { color: var(--nc-primary); }
.nc-menu > li:hover > a::after { transform: scaleX(1); }

/* Dropdown */
.nc-menu > li { position: relative; }
.nc-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 2px);
  left: 0;
  background: #fff;
  border: 1px solid var(--nc-border);
  border-radius: var(--nc-radius);
  box-shadow: var(--nc-shadow-lg);
  min-width: 200px;
  padding: 8px 0;
  z-index: 999;
  list-style: none;
  margin: 0;
  animation: dropFade .18s ease;
}
.nc-menu > li:hover .nc-dropdown { display: block; }
.nc-dropdown li a {
  display: block;
  padding: 9px 18px;
  font-size: 13px;
  color: var(--nc-text);
  text-decoration: none;
  transition: var(--nc-transition);
}
.nc-dropdown li a:hover {
  background: var(--nc-primary-light);
  color: var(--nc-primary);
  padding-left: 22px;
}
.nc-dropdown.wide { min-width: 440px; display: none; }
.nc-menu > li:hover .nc-dropdown.wide { display: flex; flex-wrap: wrap; }
.nc-dropdown.wide li { width: 50%; }

@keyframes dropFade {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Mobile toggle */
.nc-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px;
  border-radius: var(--nc-radius-sm);
  transition: var(--nc-transition);
}
.nc-toggle:hover { background: var(--nc-primary-light); }
.nc-toggle span {
  display: block;
  width: 22px; height: 2px;
  background: var(--nc-primary);
  border-radius: 2px;
  transition: var(--nc-transition);
}
.nc-toggle.open span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.nc-toggle.open span:nth-child(2) { opacity: 0; }
.nc-toggle.open span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* Mobile nav drawer */
.nc-nav-mobile {
  display: none;
  padding: 8px 0 16px;
  border-top: 1px solid var(--nc-border);
}
.nc-nav-mobile.open { display: block; }
.nc-nav-mobile .nc-menu { flex-direction: column; align-items: stretch; gap: 0; }
.nc-nav-mobile .nc-menu > li > a { padding: 11px 20px; font-size: 14px; }
.nc-nav-mobile .nc-menu > li > a::after { display: none; }
.nc-nav-mobile .nc-dropdown {
  display: none !important;
  position: static;
  box-shadow: none;
  border: none;
  background: var(--nc-primary-light);
  border-radius: 0;
  padding: 4px 0;
}
.nc-nav-mobile .nc-menu > li.nc-open .nc-dropdown { display: block !important; }
.nc-mobile-search {
  padding: 10px 16px 4px;
}
.nc-mobile-search .nc-search-form { max-width: 100%; }

/* ── 5. BREADCRUMB ──────────────────────────────────────────── */
.breadcrumb {
  background: transparent !important;
  padding: 14px 0 6px !important;
  border-radius: 0 !important;
  margin: 0 !important;
  font-size: 12px;
}
.breadcrumb > li + li::before { color: var(--nc-text-muted) !important; }
.breadcrumb > .active { color: var(--nc-primary) !important; font-weight: 500; }
.breadcrumb a { color: var(--nc-text-muted); }
.breadcrumb a:hover { color: var(--nc-primary); }

/* ── 6. BOTÕES ──────────────────────────────────────────────── */
.btn {
  font-family: var(--nc-font) !important;
  font-weight: 600 !important;
  border-radius: var(--nc-radius-sm) !important;
  letter-spacing: .2px;
  transition: var(--nc-transition) !important;
  border: none !important;
}
.btn-primary {
  background: var(--nc-primary) !important;
  color: #fff !important;
}
.btn-primary:hover, .btn-primary:focus {
  background: var(--nc-primary-dark) !important;
  color: #fff !important;
  box-shadow: 0 4px 14px rgba(var(--nc-primary-rgb),.35) !important;
}
.btn-success {
  background: var(--nc-success) !important;
  color: #fff !important;
}
.btn-success:hover { background: #237a34 !important; }
.btn-danger {
  background: var(--nc-danger) !important;
  color: #fff !important;
}
.btn-warning {
  background: var(--nc-warning) !important;
  color: #fff !important;
}
.btn-warning:hover { color: #fff !important; background: #d48600 !important; }
.btn-default {
  background: #fff !important;
  color: var(--nc-text) !important;
  border: 1.5px solid var(--nc-border) !important;
}
.btn-default:hover { border-color: var(--nc-primary) !important; color: var(--nc-primary) !important; }

/* ── 7. FORMULÁRIOS ─────────────────────────────────────────── */
.form-control {
  font-family: var(--nc-font) !important;
  border: 1.5px solid var(--nc-border) !important;
  border-radius: var(--nc-radius-sm) !important;
  font-size: 13px;
  color: var(--nc-text);
  transition: var(--nc-transition);
}
.form-control:focus {
  border-color: var(--nc-accent) !important;
  box-shadow: 0 0 0 3px rgba(200,126,181,.15) !important;
  outline: none;
}

/* ── 8. CARDS GENÉRICOS ─────────────────────────────────────── */
.nc-card {
  background: var(--nc-card-bg);
  border-radius: var(--nc-radius);
  box-shadow: var(--nc-shadow-sm);
  border: 1px solid var(--nc-border);
  padding: 20px;
  transition: var(--nc-transition);
}
.nc-card:hover { box-shadow: var(--nc-shadow); }

/* ── 9. PRODUTOS — GRID ─────────────────────────────────────── */
/* Override old Bootstrap 3 product card styles */
.product-image-wrapper {
  border: 1px solid var(--nc-border) !important;
  border-radius: var(--nc-radius) !important;
  overflow: hidden !important;
  transition: var(--nc-transition) !important;
  background: #fff !important;
  margin-bottom: 24px !important;
  box-shadow: var(--nc-shadow-sm) !important;
}
.product-image-wrapper:hover {
  border-color: var(--nc-accent) !important;
  box-shadow: var(--nc-shadow) !important;
  transform: translateY(-3px);
}
.single-products { height: auto !important; }
.productinfo {
  padding: 16px 14px 0 !important;
  text-align: center !important;
}
.productinfo img {
  width: 160px !important;
  height: 180px !important;
  object-fit: contain !important;
  margin: 0 auto 10px !important;
  display: block !important;
}
.productinfo h2 {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--nc-primary) !important;
  margin: 6px 0 4px !important;
  line-height: 1.3 !important;
}
.productinfo h2.price-original {
  font-size: 12px !important;
  color: var(--nc-text-muted) !important;
  text-decoration: line-through !important;
  font-weight: 400 !important;
}
.productinfo p {
  font-size: 13px !important;
  color: var(--nc-text) !important;
  font-weight: 800 !important;
  margin: 12px 10px 8px !important;
  line-height: 1.45 !important;
  text-align: center !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  min-height: 38px !important;
}
.product-image-wrapper .btn-primary {
  width: calc(100% - 28px) !important;
  margin: 0 14px 14px !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  padding: 8px !important;
}

.choose {
  border-top: 1px solid var(--nc-border) !important;
  background: var(--nc-bg) !important;
}
.choose ul { margin: 0 !important; padding: 0 !important; }
.choose ul li a {
  color: var(--nc-primary) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  padding: 8px 0 !important;
  font-family: var(--nc-font) !important;
}
.choose ul li a:hover { background: var(--nc-primary-light) !important; }

/* Badge "novo" / "promoção" / "frete grátis" */
.new {
  position: absolute !important;
  top: 10px !important; right: 10px !important;
  width: 56px !important; height: auto !important;
  border-radius: 4px !important;
}

/* Product grid title */
h1.title, h2.title {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--nc-text) !important;
  text-transform: none !important;
  margin-bottom: 20px !important;
}
h1.text-center {
  font-size: 22px !important;
  font-weight: 700 !important;
  color: var(--nc-text) !important;
}

/* ── 10. PRODUTO DETALHE ────────────────────────────────────── */
.product-details { padding: 10px 0; }
.product-information {
  padding: 20px 24px !important;
}
.product-information h1 {
  font-size: 22px !important;
  font-weight: 700 !important;
  color: var(--nc-text) !important;
  margin: 0 0 8px !important;
}
.product-information h2 {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--nc-primary) !important;
  margin: 14px 0 4px !important;
}
.product-information p { font-size: 13px; line-height: 1.7; color: #444; }
.product-information .price-box {
  font-size: 28px;
  font-weight: 700;
  color: var(--nc-primary);
  margin: 16px 0 20px;
}
.product-information .price-original {
  font-size: 14px;
  color: var(--nc-text-muted);
  text-decoration: line-through;
  margin-bottom: 4px;
}

/* ── 11. CARRINHO ───────────────────────────────────────────── */
#cart_items { padding: 20px 0 40px; }
#cart_items h3 {
  font-size: 20px !important;
  font-weight: 700 !important;
  color: var(--nc-text) !important;
}
.cart_info table {
  width: 100%;
  border-collapse: collapse;
}
.cart_info .cart_menu th {
  background: var(--nc-primary) !important;
  color: #fff !important;
  font-family: var(--nc-font) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .4px !important;
  padding: 12px 14px !important;
  border: none !important;
}
.cart_info table tbody tr {
  border-bottom: 1px solid var(--nc-border);
  transition: var(--nc-transition);
}
.cart_info table tbody tr:hover { background: var(--nc-primary-light); }
.cart_info table td {
  padding: 12px 14px;
  font-size: 13px;
  vertical-align: middle;
}
.cart_info table td img {
  width: 60px !important;
  height: 60px !important;
  object-fit: cover;
  border-radius: var(--nc-radius-sm);
}

/* Cart totals */
.cart_totalitem, .cart_total {
  background: var(--nc-primary-light);
  border-radius: var(--nc-radius);
  padding: 20px 24px !important;
  margin-top: 16px !important;
}
.cart_totalitem h4, .cart_total h4 {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--nc-primary) !important;
}

/* ── 12. HOMEPAGE SECTIONS ──────────────────────────────────── */
/* Banner slider */
#slider {
  margin: 0 0 32px !important;
  padding: 16px 0 0 !important;
}
#slider .container { padding-left: 15px; padding-right: 15px; }
#slider-carousel {
  border-radius: var(--nc-radius-lg) !important;
  overflow: hidden !important;
  box-shadow: var(--nc-shadow-lg) !important;
  background: var(--nc-primary-light) !important;
}
#slider-carousel .item > div {
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
}
#slider-carousel .item > div > a {
  display: block;
  line-height: 0;
}
#slider-carousel img {
  width: 100% !important;
  height: auto !important;
  max-height: 480px !important;
  object-fit: cover !important;
  border-radius: 0 !important;
  display: block !important;
}
/* Carousel dots */
#slider-carousel .carousel-indicators {
  bottom: 12px !important;
  margin: 0 !important;
}
#slider-carousel .carousel-indicators li {
  width: 8px !important; height: 8px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,.55) !important;
  border: none !important;
  margin: 0 3px !important;
  transition: all .2s !important;
}
#slider-carousel .carousel-indicators li.active {
  background: #fff !important;
  width: 22px !important;
  border-radius: 4px !important;
}
/* Arrow buttons */
.control-carousel {
  background: rgba(255,255,255,.88) !important;
  border-radius: 50% !important;
  width: 40px !important;
  height: 40px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--nc-primary) !important;
  font-size: 16px !important;
  line-height: 1 !important;
  text-decoration: none !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  margin-top: 0 !important;
  transition: var(--nc-transition) !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.18) !important;
}
.control-carousel:hover {
  background: var(--nc-primary) !important;
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(61,18,53,.35) !important;
}
.left.control-carousel { left: 14px !important; }
.right.control-carousel { right: 14px !important; }

/* Homepage product title */
#ponto h1 { font-size: 20px !important; font-weight: 700 !important; }

/* Category sidebar */
.left-sidebar h2 {
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .5px !important;
  color: var(--nc-text) !important;
  padding: 10px 14px !important;
  background: var(--nc-primary-light) !important;
  border-radius: var(--nc-radius-sm) !important;
  margin: 0 0 2px !important;
}
.panel-group { margin-bottom: 16px !important; }
.panel { border: none !important; box-shadow: none !important; border-radius: 0 !important; }
.panel-default > .panel-heading {
  background: #fff !important;
  border: none !important;
  padding: 0 !important;
}
.panel-title a {
  /* display left intentionally without !important so inline display:flex can win */
  padding: 9px 14px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--nc-text) !important;
  border-bottom: 1px solid var(--nc-border) !important;
  text-decoration: none !important;
}
.panel-title a:hover { background: var(--nc-primary-light) !important; color: var(--nc-primary) !important; }
.panel-body { padding: 6px 0 !important; }
.panel-body ul li a { font-size: 12px !important; color: var(--nc-text-muted) !important; padding: 6px 24px !important; }
.panel-body ul li a:hover { color: var(--nc-primary) !important; text-decoration: none !important; }
.badge.pull-right {
  background: var(--nc-primary) !important;
  border-radius: 4px !important;
}

/* ── 13. ALERTS / MENSAGENS ─────────────────────────────────── */
.alert { border-radius: var(--nc-radius-sm) !important; border: none !important; font-family: var(--nc-font) !important; font-size: 13px !important; }
.alert-info { background: #e8f0fb !important; color: var(--nc-info) !important; }
.alert-success { background: #d3f9d8 !important; color: var(--nc-success) !important; }
.alert-danger { background: #ffe3e3 !important; color: var(--nc-danger) !important; }
.alert-warning { background: #fff3cd !important; color: #856404 !important; }

/* Alertas de frete dentro do modal carrinho */
#modalCarrinho .alert-success {
  background: #e6f4ea !important;
  color: #1e6f38 !important;
  border-left: 3px solid #2f9e44 !important;
  font-weight: 600 !important;
  padding: 10px 14px !important;
  border-radius: 8px !important;
}
#modalCarrinho .alert-danger {
  background: var(--nc-primary-light) !important;
  color: var(--nc-primary) !important;
  border-left: 3px solid var(--nc-accent) !important;
  font-weight: 500 !important;
  padding: 10px 14px !important;
  border-radius: 8px !important;
}

/* Checkout modal — botão de calcular frete */
.btn-check-frete {
  background: var(--nc-primary) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 8px !important;
  font-weight: 600 !important;
}
.btn-check-frete:hover, .btn-check-frete:focus {
  background: var(--nc-primary-dark) !important;
  color: #fff !important;
}

/* ── Modal genérico overrides ───────────────────────────────── */
.modal-content {
  border-radius: 12px !important;
  border: none !important;
  box-shadow: 0 24px 64px rgba(61,18,53,.2) !important;
  font-family: var(--nc-font) !important;
}
.modal-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  border-bottom: 1px solid var(--nc-border) !important;
  padding: 16px 20px !important;
}
.modal-footer {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  border-top: 1px solid var(--nc-border) !important;
  padding: 14px 20px !important;
  background: #fff !important;
}

/* ── 14. FOOTER ─────────────────────────────────────────────── */
/* Remove old footer */
#footer { all: unset !important; display: block !important; }
.footer-widget, .footer-bottom, .single-widget { all: unset !important; display: block !important; }

.nc-footer {
  background: var(--nc-primary);
  color: #e8d5e4;
  margin-top: 48px;
}
.nc-footer-top {
  padding: 48px 0 36px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.nc-footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.4fr;
  gap: 36px;
}
.nc-footer-brand img {
  height: 40px;
  width: auto;
  filter: brightness(0) invert(1);
  margin-bottom: 14px;
}
.nc-footer-brand p {
  font-size: 13px;
  color: rgba(255,255,255,.65);
  line-height: 1.7;
  margin-bottom: 16px;
}
.nc-footer-col h4 {
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  color: #fff !important;
  margin: 0 0 14px !important;
}
.nc-footer-col ul {
  list-style: none;
  padding: 0; margin: 0;
}
.nc-footer-col ul li { margin-bottom: 8px; }
.nc-footer-col ul li a {
  font-size: 13px;
  color: rgba(255,255,255,.65) !important;
  text-decoration: none;
  transition: var(--nc-transition);
}
.nc-footer-col ul li a:hover { color: var(--nc-accent) !important; padding-left: 4px; }

/* Newsletter in footer */
.nc-footer-newsletter { margin-top: 20px; }
.nc-footer-newsletter h4 { margin-top: 0 !important; }
.nc-footer-newsletter .nc-input-group {
  display: flex;
  gap: 0;
  margin-top: 8px;
}
.nc-footer-newsletter input {
  flex: 1;
  height: 38px;
  border: none;
  border-radius: 6px 0 0 6px;
  padding: 0 12px;
  font-size: 13px;
  background: rgba(255,255,255,.12);
  color: #fff;
  outline: none;
}
.nc-footer-newsletter input::placeholder { color: rgba(255,255,255,.45); }
.nc-footer-newsletter input:focus { background: rgba(255,255,255,.2); }
.nc-footer-newsletter button {
  height: 38px;
  padding: 0 14px;
  background: var(--nc-accent);
  border: none;
  border-radius: 0 6px 6px 0;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  font-family: var(--nc-font);
  cursor: pointer;
  transition: var(--nc-transition);
}
.nc-footer-newsletter button:hover { background: var(--nc-accent-dark); }

.nc-social-links {
  display: flex;
  gap: 8px;
  margin-top: 14px;
}
.nc-social-link {
  width: 34px; height: 34px;
  border-radius: 50%;
  background: rgba(255,255,255,.12);
  display: flex; align-items: center; justify-content: center;
  color: #fff !important;
  font-size: 14px;
  text-decoration: none;
  transition: var(--nc-transition);
}
.nc-social-link:hover { background: var(--nc-accent); color: #fff !important; }

.nc-footer-bottom {
  padding: 16px 0;
  background: var(--nc-primary-dark);
}
.nc-footer-bottom-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}
.nc-footer-bottom p {
  margin: 0;
  font-size: 12px;
  color: rgba(255,255,255,.5) !important;
}
.nc-footer-bottom a { color: var(--nc-accent) !important; }
.nc-payment-icons { display: flex; gap: 6px; align-items: center; }
.nc-payment-icons span {
  background: rgba(255,255,255,.12);
  border-radius: 4px;
  padding: 3px 8px;
  font-size: 10px;
  font-weight: 700;
  color: rgba(255,255,255,.7);
  letter-spacing: .5px;
}

/* ── 15. WHATSAPP FLOAT ─────────────────────────────────────── */
.nc-wa-float {
  position: fixed;
  bottom: 28px; right: 24px;
  z-index: 10000;
  display: flex;
  align-items: center;
  gap: 10px;
}
.nc-wa-btn {
  width: 54px; height: 54px;
  border-radius: 50%;
  background: #25D366;
  display: flex; align-items: center; justify-content: center;
  color: #fff !important;
  font-size: 26px;
  text-decoration: none;
  box-shadow: 0 4px 14px rgba(37,211,102,.4);
  transition: var(--nc-transition);
  flex-shrink: 0;
}
.nc-wa-btn:hover { background: #1ebe59; transform: scale(1.08); color: #fff !important; }
.nc-wa-bubble {
  background: #fff;
  border-radius: 20px;
  padding: 8px 14px;
  font-size: 12px;
  font-weight: 600;
  color: var(--nc-text);
  box-shadow: var(--nc-shadow);
  white-space: nowrap;
  animation: waBubble 4s ease infinite;
}
@keyframes waBubble {
  0%,100% { opacity: 1; }
  50%      { opacity: .7; }
}

/* ── 16. COOKIE BANNER ──────────────────────────────────────── */
.nc-cookie {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: var(--nc-primary-dark);
  color: rgba(255,255,255,.85);
  padding: 14px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  z-index: 9999;
  font-size: 13px;
  box-shadow: 0 -4px 16px rgba(0,0,0,.2);
  flex-wrap: wrap;
}
.nc-cookie p { margin: 0; flex: 1; }
.nc-cookie-btns { display: flex; gap: 8px; flex-shrink: 0; }
.nc-cookie .btn-cookie-accept {
  background: var(--nc-accent);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 7px 18px;
  font-size: 12px;
  font-weight: 600;
  font-family: var(--nc-font);
  cursor: pointer;
  transition: var(--nc-transition);
}
.nc-cookie .btn-cookie-accept:hover { background: var(--nc-accent-dark); }
.nc-cookie .btn-cookie-close {
  background: transparent;
  border: 1px solid rgba(255,255,255,.3);
  color: rgba(255,255,255,.7);
  border-radius: 6px;
  padding: 7px 14px;
  font-size: 12px;
  cursor: pointer;
  font-family: var(--nc-font);
}

/* ── 17. SEÇÕES / PÁGINAS ESTÁTICAS ─────────────────────────── */
#advertisement { padding: 20px 0 10px; }
section { padding: 10px 0; }

/* Page sections */
.nc-section-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--nc-text);
  margin: 0 0 4px;
}
.nc-section-sub {
  font-size: 13px;
  color: var(--nc-text-muted);
  margin-bottom: 24px;
}

/* Blog */
.nc-blog-card {
  background: #fff;
  border-radius: var(--nc-radius);
  border: 1px solid var(--nc-border);
  overflow: hidden;
  box-shadow: var(--nc-shadow-sm);
  transition: var(--nc-transition);
  margin-bottom: 24px;
}
.nc-blog-card:hover { box-shadow: var(--nc-shadow); transform: translateY(-2px); }
.nc-blog-card img { width: 100%; height: 180px; object-fit: cover; }
.nc-blog-card-body { padding: 16px 18px 20px; }
.nc-blog-card h3 { font-size: 16px; font-weight: 600; margin-bottom: 8px; }
.nc-blog-card p { font-size: 13px; color: var(--nc-text-muted); line-height: 1.6; }

/* FAQ */
.nc-faq-item {
  border: 1px solid var(--nc-border);
  border-radius: var(--nc-radius-sm);
  margin-bottom: 10px;
  overflow: hidden;
}
.nc-faq-q {
  padding: 14px 18px;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #fff;
  transition: var(--nc-transition);
}
.nc-faq-q:hover { background: var(--nc-primary-light); color: var(--nc-primary); }
.nc-faq-a {
  padding: 14px 18px;
  font-size: 13px;
  line-height: 1.7;
  color: var(--nc-text-muted);
  border-top: 1px solid var(--nc-border);
  background: var(--nc-bg);
}

/* Texto institucional */
.nc-text-page { max-width: 820px; margin: 0 auto; padding: 24px 0 48px; }
.nc-text-page h1 { font-size: 24px; margin-bottom: 20px; }
.nc-text-page h2 { font-size: 18px; margin: 24px 0 10px; color: var(--nc-primary); }
.nc-text-page p { font-size: 14px; line-height: 1.8; color: #444; margin-bottom: 14px; }

/* ── 18. RESPONSIVIDADE ─────────────────────────────────────── */
@media (max-width: 991px) {
  .nc-footer-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .nc-footer-brand { grid-column: 1 / -1; }
  .nc-search-form { max-width: 300px; }
}

@media (max-width: 767px) {
  /* Tipografia */
  h1.text-center { font-size: 18px !important; }
  .product-information h1 { font-size: 18px !important; }

  /* ── Header mobile ── */
  .nc-header-main {
    grid-template-columns: auto 1fr auto;
    padding: 10px 0;
    gap: 0;
  }
  .nc-logo { justify-content: center; }
  .nc-search-form { display: none !important; }
  .nc-toggle { display: flex; }
  .nc-header-actions { justify-content: flex-end; }

  /* Esconde nav desktop — só o drawer mobile é usado */
  .nc-nav { display: none !important; }

  /* Esconde ações secundárias — ficam apenas no drawer */
  .nc-action-link:not(.nc-cart) { display: none !important; }

  /* Carrinho: ícone + quantidade em linha */
  .nc-action-link.nc-cart {
    flex-direction: row !important;
    gap: 6px !important;
    padding: 7px 12px !important;
    border-radius: 20px !important;
    background: var(--nc-primary) !important;
    color: #fff !important;
  }
  .nc-action-link.nc-cart:hover { background: var(--nc-primary-dark) !important; }
  .nc-action-link.nc-cart span { display: inline !important; font-size: 12px !important; font-weight: 700 !important; }
  .nc-action-link.nc-cart i { font-size: 16px !important; color: #fff !important; }

  .nc-menu > li > a { padding: 12px 20px; font-size: 14px; border-bottom: 1px solid var(--nc-border); }

  /* ── Produto detalhe: centraliza coluna de info no mobile ── */
  .nc-product-info {
    padding-left: 16px !important;
    padding-right: 16px !important;
    text-align: center !important;
  }
  .nc-product-info h1,
  .nc-product-info p,
  .nc-product-info > div { text-align: center !important; }

  /* Descrição do produto */
  .nc-product-info [style*="line-height:1.7"] {
    text-align: left !important;
    padding: 0 4px !important;
  }

  /* Bloco de preço: centraliza conteúdo interno */
  .nc-product-info .nc-price-box { align-items: center !important; }

  /* Badge de desconto: centraliza */
  .nc-product-info [style*="dcfce7"] { margin-left: auto; margin-right: auto; }

  /* Form comprar: centraliza linha qtd+botão */
  .nc-product-info form > div[style*="display:flex"] {
    justify-content: center !important;
  }

  /* Trust icons row */
  .nc-trust-row {
    justify-content: center !important;
  }

  /* Share buttons */
  .nc-product-info [style*="display:flex"][style*="gap:8px"] {
    justify-content: center !important;
  }

  /* Products grid — 2 columns on mobile */
  /* Note: col-xs-6 already handles 2-col on mobile, only override col-sm-3 inside product grids */
  #ponto .col-sm-3,
  #recommended-item-carousel .col-sm-3 { width: 50% !important; float: left; }
  /* Category sidebar stays full-width */
  .left-sidebar { width: 100% !important; }
  .productinfo img { width: 100% !important; height: 140px !important; }

  /* Footer */
  .nc-footer-grid { grid-template-columns: 1fr; gap: 22px; }
  .nc-footer-top { padding: 28px 0 22px; }
  .nc-footer-bottom-inner { flex-direction: column; text-align: center; }

  /* Cart table */
  .cart_info table { display: block; overflow-x: auto; }
}

@media (max-width: 480px) {
  #ponto .col-sm-3,
  #recommended-item-carousel .col-sm-3,
  .col-xs-6 { width: 100% !important; float: none; }
  .productinfo img { height: 200px !important; }
  .nc-wa-bubble { display: none; }
}

/* ── 19. ANIMAÇÕES GLOBAIS ──────────────────────────────────── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
.nc-fade-up { animation: fadeUp .4s ease both; }

/* ── 20. UTILITÁRIOS ────────────────────────────────────────── */
.nc-tag {
  display: inline-block;
  background: var(--nc-primary-light);
  color: var(--nc-primary);
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
}
.nc-tag-green  { background: #d3f9d8; color: var(--nc-success); }
.nc-tag-orange { background: #fff3cd; color: #856404; }
.nc-tag-blue   { background: #e8f0fb; color: var(--nc-info); }
.text-primary  { color: var(--nc-primary) !important; }

/* Back to top */
#scrollUp {
  background: var(--nc-primary) !important;
  border-radius: 50% !important;
  width: 40px !important;
  height: 40px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  bottom: 90px !important;
}

/* Pagination */
.pagination > li > a {
  color: var(--nc-primary) !important;
  border-radius: 6px !important;
  margin: 0 2px !important;
  border: 1px solid var(--nc-border) !important;
  font-family: var(--nc-font) !important;
  font-weight: 500 !important;
}
.pagination > .active > a {
  background: var(--nc-primary) !important;
  border-color: var(--nc-primary) !important;
  color: #fff !important;
}
.pagination > li > a:hover { background: var(--nc-primary-light) !important; }
