@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow+Condensed:wght@400;500;600;700;800&family=Barlow:wght@300;400;500;600&display=swap');

:root {
  --white:      #FFFFFF;
  --bg:         #F4F4F4;
  --border:     #E4E4E4;
  --gray-light: #EBEBEB;
  --gray-mid:   #9B9B9B;
  --gray-dark:  #555555;
  --black:      #111111;
  --red:        #D9191F;
  --red-hover:  #B81218;
  --yellow:     #F5C400;
  --green:      #25D366;
  --green-h:    #1EBA58;
  --blue:       #3b00c4;
  --font-brand: 'Bebas Neue', sans-serif;
  --font-head:  'Barlow Condensed', sans-serif;
  --font-body:  'Barlow', sans-serif;
  --shadow-sm:  0 1px 4px rgba(0,0,0,0.06);
  --shadow-md:  0 4px 20px rgba(0,0,0,0.10);
  --ease:       all 0.22s ease;
  --header-h:   54px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-body); background: var(--bg); color: var(--black); -webkit-font-smoothing: antialiased; overflow-x: hidden; min-height: 100dvh; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; }

.logo { flex-direction: row; align-items: center; gap: 8px; }
.logo-text-wrap { display: flex; flex-direction: column; line-height: 1; }

/* ===== SITE SHELL ===== */
.site-shell { display: flex; flex-direction: column; min-height: 100dvh; }
.page-content { flex: 1; }

/* ===== TURBO PROGRESS BAR ===== */
/* O Turbo cria automaticamente um <div class="turbo-progress-bar"> no topo
   durante navegações Drive. Estilizamos pra combinar com o tema vermelho. */
.turbo-progress-bar {
  position: fixed; top: 0; left: 0;
  height: 2px;
  background: var(--red);
  box-shadow: 0 0 8px rgba(217,25,31,.55);
  z-index: 9999;
  transition: width 300ms ease-out, opacity 150ms 150ms ease-in;
  transform: translate3d(0, 0, 0);
}

/* ===== STICKY SHELL ===== */
.sticky-shell { position: sticky; top: 0; z-index: 100; background: var(--white); transition: background 0.3s ease; }
.sticky-shell.scrolled { background: var(--red); }
.sticky-shell.scrolled .header { border-bottom-color: rgba(255,255,255,.15); }
.sticky-shell.scrolled .logo-top, .sticky-shell.scrolled .logo-top span { color: var(--white); }
.sticky-shell.scrolled .logo-sub { color: rgba(255,255,255,.55); }
.sticky-shell.scrolled .nav-link { color: rgba(255,255,255,.7); }
.sticky-shell.scrolled .nav-link:hover, .sticky-shell.scrolled .nav-link.active { color: var(--white); }
.sticky-shell.scrolled .header-icon { color: var(--white); }
.sticky-shell.scrolled .header-icon:hover { color: rgba(255,255,255,.7); }
.sticky-shell.scrolled .hamburger span { background: var(--white); }
.sticky-shell.scrolled .cart-badge { background: var(--black); color: var(--white); border: 1.5px solid rgba(255,255,255,.2); }
.sticky-shell.scrolled .search-bar { background: var(--red-hover); border-bottom-color: rgba(255,255,255,.15); }
.sticky-shell.scrolled .search-input { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.25); color: var(--white); }
.sticky-shell.scrolled .search-input::placeholder { color: rgba(255,255,255,.45); }
.sticky-shell.scrolled .search-close { color: rgba(255,255,255,.7); }
.sticky-shell.scrolled .mobile-nav { background: var(--red-hover); border-bottom-color: rgba(255,255,255,.12); }
.sticky-shell.scrolled .mob-link { color: rgba(255,255,255,.75); }
.sticky-shell.scrolled .mob-link i { color: rgba(255,255,255,.5); }
.sticky-shell.scrolled .mob-link:hover { color: var(--white); border-left-color: var(--white); }

/* ===== HEADER ===== */
.header { border-bottom: 1px solid var(--border); height: var(--header-h); display: flex; align-items: center; padding: 0 14px; }
.header-inner { display: flex; align-items: center; justify-content: space-between; width: 100%; max-width: 1400px; margin: 0 auto; gap: 12px; }
.logo { display: flex; flex-direction: column; line-height: 1; user-select: none; flex-shrink: 0; }
.logo-top { font-family: var(--font-brand); font-size: 24px; letter-spacing: 2.5px; color: var(--black); line-height: 1; }
.logo-top span { color: var(--red); }
.logo-sub { font-family: var(--font-head); font-size: 8px; font-weight: 600; letter-spacing: 3px; color: var(--gray-mid); text-transform: uppercase; line-height: 1; margin-top: 1px; }
.desktop-nav { display: none; align-items: center; gap: 2px; flex: 1; justify-content: center; }
@media (min-width: 960px) { .desktop-nav { display: flex; } }
.nav-link { font-family: var(--font-head); font-size: 13px; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; color: var(--gray-dark); padding: 7px 12px; transition: var(--ease); background: none; border: none; white-space: nowrap; display: block; }
.nav-link:hover, .nav-link.active { color: var(--black); }
.header-actions { display: flex; align-items: center; gap: 2px; flex-shrink: 0; }
.header-icon { font-size: 17px; color: var(--black); background: none; border: none; display: flex; align-items: center; padding: 8px; position: relative; transition: var(--ease); }
.header-icon:hover { color: var(--red); }
.cart-badge { position: absolute; top: 3px; right: 3px; background: var(--red); color: white; font-size: 9px; font-weight: 700; width: 15px; height: 15px; border-radius: 50%; display: none; align-items: center; justify-content: center; }
.hamburger { display: flex; flex-direction: column; justify-content: center; gap: 4.5px; padding: 8px; background: none; border: none; }
@media (min-width: 960px) { .hamburger { display: none; } }
.hamburger span { display: block; width: 18px; height: 1.5px; background: var(--black); transition: var(--ease); }
.hamburger.open span:nth-child(1) { transform: rotate(45deg) translate(4px,4px); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: rotate(-45deg) translate(4px,-4px); }
.mobile-nav { border-bottom: 1px solid var(--border); overflow: hidden; max-height: 0; transition: max-height 0.28s cubic-bezier(0.4,0,0.2,1); }
.mobile-nav.open { max-height: 300px; }
.mobile-nav-inner { padding: 6px 0 10px; max-width: 1400px; margin: 0 auto; }
.mob-link { display: flex; align-items: center; gap: 12px; padding: 12px 20px; font-family: var(--font-head); font-size: 14px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--black); transition: var(--ease); background: none; border: none; width: 100%; border-left: 3px solid transparent; }
.mob-link i { color: var(--gray-mid); font-size: 13px; width: 18px; text-align: center; flex-shrink: 0; }
.mob-link:hover { color: var(--red); border-left-color: var(--red); }
.mob-link:hover i { color: var(--red); }
.search-bar { border-bottom: 1px solid var(--border); padding: 0 14px; max-height: 0; overflow: hidden; transition: max-height 0.25s ease, padding 0.25s ease; }
.search-bar.open { max-height: 60px; padding: 10px 14px; }
.search-form { display: flex; gap: 10px; align-items: center; max-width: 1400px; margin: 0 auto; }
.search-input { flex: 1; padding: 9px 12px; border: 1.5px solid var(--border); background: var(--bg); font-family: var(--font-body); font-size: 13px; color: var(--black); outline: none; transition: var(--ease); border-radius: 0; -webkit-appearance: none; }
.search-input:focus { border-color: var(--red); background: var(--white); }
.search-input::placeholder { color: #bbb; }
.search-close { background: none; border: none; color: var(--gray-mid); font-size: 17px; padding: 4px; transition: var(--ease); }
.search-close:hover { color: var(--black); }

/* ===== HERO ===== */
.hero { position: relative; overflow: hidden; min-height: 82vw; max-height: 620px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 56px 16px 48px; background: var(--black); }
@media (min-width: 768px) { .hero { min-height: 520px; max-height: 700px; } }
.hero-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.70); z-index: 1; }
/* ── Banner carousel ── */
.banner-slides { position: absolute; inset: 0; }
.banner-slide { position: absolute; inset: 0; background-size: cover; background-position: center; background-repeat: no-repeat; background-color: var(--black); opacity: 0; transition: opacity .8s ease; display: flex; align-items: center; justify-content: center; }
.banner-slide.active { opacity: 1; }
.banner-slide::before { content: ''; position: absolute; inset: 0; background: rgba(0,0,0,.40); z-index: 1; pointer-events: none; }
.banner-slide-inner { position: relative; z-index: 2; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 28px; padding: 0 24px; max-width: 860px; }
.banner-text { font-family: var(--font-head); font-size: clamp(20px, 4.5vw, 42px); font-weight: 700; color: var(--white); text-shadow: 0 2px 12px rgba(0,0,0,.7); letter-spacing: .5px; line-height: 1.15; }
.banner-arrow { position: absolute; top: 50%; transform: translateY(-50%); z-index: 10; width: 44px; height: 44px; background: rgba(0,0,0,.45); border: none; color: #fff; font-size: 16px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .2s; }
.banner-arrow:hover { background: rgba(0,0,0,.78); }
.banner-arrow--prev { left: 14px; }
.banner-arrow--next { right: 14px; }
.banner-dots { position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%); z-index: 10; display: flex; gap: 8px; }
.banner-dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.45); border: none; cursor: pointer; padding: 0; transition: background .2s, transform .2s; }
.banner-dot.active { background: var(--white); transform: scale(1.35); }
.hero-overlay::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent, var(--red), transparent); }
.hero-content { position: relative; z-index: 2; }
.hero-content-logo { display: flex; flex-direction: column; align-items: center; gap: 32px; padding: 0 20px; max-width: 100%; }
.hero-tag { display: inline-block; background: var(--red); color: white; font-family: var(--font-head); font-size: 10px; font-weight: 700; letter-spacing: 3px; padding: 4px 12px; margin-bottom: 18px; text-transform: uppercase; }
.hero-title { font-family: var(--font-head); font-size: clamp(52px, 14vw, 96px); font-weight: 800; line-height: 0.92; letter-spacing: -0.5px; text-transform: uppercase; color: var(--white); margin-bottom: 18px; }
.hero-title em { font-style: normal; color: var(--red); }
.hero-sub { font-size: 12px; color: rgba(255,255,255,.5); letter-spacing: 2.5px; text-transform: uppercase; margin-bottom: 28px; }
.hero-btn { display: inline-flex; align-items: center; gap: 8px; background: var(--white); color: var(--black); font-family: var(--font-head); font-size: 13px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; padding: 12px 28px; border: 2px solid var(--white); transition: var(--ease); }
.hero-btn:hover { background: var(--red); color: white; border-color: var(--red); }

/* ── Texto fino "A.M Colecionáveis" — hero fallback ── */
.hero-thin-title {
  font-family: var(--font-head);
  font-size: clamp(28px, 6vw, 62px);
  font-weight: 300;
  letter-spacing: clamp(2px, 1.2vw, 10px);
  text-transform: uppercase;
  color: var(--white);
  text-align: center;
  line-height: 1;
  margin: 0;
  text-shadow: 0 4px 24px rgba(0,0,0,.75), 0 0 18px rgba(0,0,0,.55);
  opacity: 1;
  animation: heroTitleIn 1s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes heroTitleIn {
  from { opacity: 0; transform: translateY(-10px); }
  to   { opacity: 1; transform: translateY(0);   }
}

/* ── Botão hero com cortes nas laterais (padrão dos cards/anúncios) ── */
.hero-cta-btn {
  position: relative;
  display: inline-block;
  padding: 0;
  background: transparent;
  border: none;
  text-decoration: none;
  line-height: 1;
  color: inherit;
  animation: heroTitleIn 1s cubic-bezier(.2,.8,.2,1) .1s both;
}
.hero-cta-btn-shadow {
  position: absolute;
  inset: 0;
  transform: translate(-5px, 5px);
  background: var(--red);
  clip-path: polygon(0 0, calc(100% - 14px) 0, 100% 14px, 100% 100%, 14px 100%, 0 calc(100% - 14px));
  pointer-events: none;
  z-index: 0;
  transition: transform .22s ease;
}
.hero-cta-btn-inner {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  background: var(--white);
  color: var(--black);
  font-family: var(--font-head);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  padding: 14px 32px;
  clip-path: polygon(0 0, calc(100% - 14px) 0, 100% 14px, 100% 100%, 14px 100%, 0 calc(100% - 14px));
  transition: background .22s ease, color .22s ease;
}
.hero-cta-btn:hover .hero-cta-btn-inner  { background: var(--black); color: var(--white); }
.hero-cta-btn:hover .hero-cta-btn-shadow { transform: translate(-8px, 8px); }
.hero-cta-btn:active .hero-cta-btn-shadow { transform: translate(-2px, 2px); }

/* ===== PAGE BANNER ===== */
.page-banner { position: relative; overflow: hidden; background: var(--black); display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 52px 16px 44px; }
.page-banner::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent, var(--red), transparent); }
.page-banner-tag { display: inline-block; background: var(--red); color: white; font-family: var(--font-head); font-size: 9px; font-weight: 700; letter-spacing: 3px; padding: 4px 12px; margin-bottom: 14px; text-transform: uppercase; }
.page-banner-title { font-family: var(--font-head); font-size: clamp(40px, 11vw, 76px); font-weight: 800; line-height: 0.92; letter-spacing: -0.5px; text-transform: uppercase; color: var(--white); margin-bottom: 14px; }
.page-banner-title em { font-style: normal; color: var(--red); }
.page-banner-sub { font-size: 11px; color: rgba(255,255,255,.45); letter-spacing: 2.5px; text-transform: uppercase; }

/* ===== FILTER BAR ===== */
.filter-bar { background: var(--white); border-bottom: 1px solid var(--border); overflow-x: auto; scrollbar-width: none; }
.filter-bar::-webkit-scrollbar { display: none; }
.filter-inner { display: flex; align-items: center; gap: 7px; padding: 12px 16px; white-space: nowrap; max-width: 1400px; margin: 0 auto; }
.filter-label { font-family: var(--font-head); font-size: 9px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--gray-mid); margin-right: 4px; flex-shrink: 0; }
.filter-chip-wrap { --cc: 8px; display: inline-block; flex-shrink: 0; padding: 1.5px; background: var(--border); clip-path: polygon(var(--cc) 0%, 100% 0%, 100% calc(100% - var(--cc)), calc(100% - var(--cc)) 100%, 0% 100%, 0% var(--cc)); transition: background 0.18s ease; cursor: pointer; }
.filter-chip-wrap:hover { background: #aaa; }
.filter-chip-wrap.active { background: var(--black); }
.filter-chip { --ci: 6px; display: block; font-family: var(--font-head); font-size: 12px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; padding: 7px 15px; background: var(--white); color: var(--gray-dark); border: none; white-space: nowrap; clip-path: polygon(var(--ci) 0%, 100% 0%, 100% calc(100% - var(--ci)), calc(100% - var(--ci)) 100%, 0% 100%, 0% var(--ci)); transition: background 0.18s ease, color 0.18s ease; }
.filter-chip-wrap:hover .filter-chip { background: var(--gray-light); color: var(--black); }
.filter-chip-wrap.active .filter-chip { background: var(--black); color: var(--white); }

/* ===== CARDS DE AVISO ===== */
.avisos-area { max-width: 1400px; margin: 20px auto 0; padding: 0 16px; display: flex; flex-direction: column; gap: 10px; }
.aviso-card { background: var(--black); color: var(--white); padding: 18px 22px; display: flex; align-items: flex-start; gap: 18px; clip-path: polygon(0 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 12px 100%, 0 calc(100% - 12px)); }
.aviso-card-label { font-family: var(--font-head); font-size: 11px; font-weight: 800; letter-spacing: 3px; text-transform: uppercase; color: var(--red); white-space: nowrap; padding-top: 2px; flex-shrink: 0; }
.aviso-card-divider { width: 2px; align-self: stretch; background: var(--red); flex-shrink: 0; min-height: 20px; }
.aviso-card-content { flex: 1; min-width: 0; }
.aviso-card-title { font-family: var(--font-head); font-size: 16px; font-weight: 800; letter-spacing: .5px; text-transform: uppercase; color: var(--white); margin-bottom: 4px; }
.aviso-card-msg { font-size: 13px; color: rgba(255,255,255,.7); line-height: 1.65; white-space: pre-line; }
.aviso-card-close { background: none; border: none; color: rgba(255,255,255,.35); font-size: 14px; cursor: pointer; padding: 2px 4px; transition: color .18s; flex-shrink: 0; align-self: flex-start; margin-top: 1px; }
.aviso-card-close:hover { color: var(--white); }

/* ===== CATALOG ===== */
.catalog-header { display: flex; align-items: baseline; justify-content: space-between; padding: 20px 16px 10px; max-width: 1400px; margin: 0 auto; }
.catalog-title { font-family: var(--font-head); font-size: 20px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; }
.catalog-count { font-size: 11px; color: var(--gray-mid); }
.product-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 10px; padding: 0 12px 24px; max-width: 1400px; margin: 0 auto; }
@media (min-width: 540px)  { .product-grid { gap: 12px; padding: 0 16px 24px; } }
@media (min-width: 768px)  { .product-grid { grid-template-columns: repeat(3,1fr); gap: 14px; } }
@media (min-width: 1024px) { .product-grid { grid-template-columns: repeat(4,1fr); gap: 18px; padding: 0 24px 24px; } }
@media (min-width: 1280px) { .product-grid { grid-template-columns: repeat(5,1fr); } }

/* ===== PRODUCT CARD ===== */
@keyframes cardIn { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }
.product-card { background: var(--white); border: 1px solid var(--border); overflow: hidden; transition: var(--ease); color: inherit; display: block; position: relative; animation: cardIn 0.3s ease forwards; opacity: 0; }
.product-card:hover { border-color: #ccc; box-shadow: var(--shadow-md); transform: translateY(-3px); }
.product-card:active { transform: scale(0.99); }
.card-image-wrap { position: relative; aspect-ratio: 3/4; overflow: hidden; background: var(--gray-light); }
.card-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s ease, opacity 0.35s ease; opacity: 0; }
.card-img.loaded { opacity: 1; }
.product-card:hover .card-img.loaded { transform: scale(1.05); }
/* Skeleton shimmer enquanto a imagem carrega */
.card-img-skeleton { position: absolute; inset: 0; background: linear-gradient(110deg, #ececec 0%, #f6f6f6 30%, #ececec 60%); background-size: 220% 100%; animation: cardSkel 1.4s linear infinite; }
@keyframes cardSkel { 0% { background-position: 220% 0; } 100% { background-position: -120% 0; } }
.card-placeholder { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; background: linear-gradient(145deg,#f0f0f0,#e6e6e6); color: #c8c8c8; gap: 6px; }
.card-placeholder i { font-size: 24px; }
.card-placeholder span { font-size: 9px; letter-spacing: 1px; text-transform: uppercase; }
.card-badges { position: absolute; top: 8px; left: 8px; display: flex; flex-direction: column; gap: 3px; z-index: 2; }
.card-badge { font-family: var(--font-head); font-size: 9px; font-weight: 700; letter-spacing: 1px; padding: 3px 8px; text-transform: uppercase; display: inline-flex; align-items: center; gap: 3px; width: fit-content; }
.card-badge.pre-venda  { background: var(--red);    color: white; }
.card-badge.novo       { background: var(--yellow);  color: var(--black); font-weight: 800; }
.card-badge.licenciado { background: var(--blue);    color: white; }
.card-body { padding: 9px 10px 10px; }
.card-studio { font-size: 8.5px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gray-mid); margin-bottom: 2px; }
.card-name { font-family: var(--font-head); font-size: 14px; font-weight: 700; line-height: 1.1; letter-spacing: 0.2px; text-transform: uppercase; margin-bottom: 7px; color: var(--black); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card-price-row { display: flex; align-items: flex-end; justify-content: space-between; gap: 6px; }
.card-price { font-family: var(--font-head); font-size: 17px; font-weight: 700; color: var(--red); line-height: 1; }
.card-installment { font-size: 8.5px; color: var(--gray-mid); margin-top: 2px; }
.card-btn { background: var(--black); color: white; display: flex; align-items: center; justify-content: center; gap: 5px; border: none; flex-shrink: 0; border-radius: 2px; font-family: var(--font-head); font-weight: 700; font-size: 12px; width: 30px; height: 30px; padding: 0; transition: var(--ease); }
.card-btn-label { display: none; font-size: 11px; letter-spacing: 0.5px; }
@media (min-width: 768px) { .card-btn { width: auto; padding: 0 12px; } .card-btn-label { display: inline; } }
.card-btn:hover { background: var(--red); }
.card-hidden { display: none !important; }
.empty-state { grid-column: 1/-1; text-align: center; padding: 56px 16px; color: var(--gray-mid); }
.empty-state i { font-size: 34px; display: block; margin-bottom: 12px; opacity: .4; }
.empty-state p { font-size: 14px; }

/* ===== LOAD MORE (infinite scroll button) ===== */
.load-more-wrap { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; padding: 18px 16px 56px; }
.load-more-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: var(--black); color: var(--white); font-family: var(--font-head); font-size: 12px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 13px 32px; border: 2px solid var(--black); transition: var(--ease); min-width: 220px; cursor: pointer; }
.load-more-btn:hover { background: var(--red); border-color: var(--red); }
.load-more-btn:disabled { opacity: .65; cursor: wait; }
.load-more-count { font-size: 11px; color: var(--gray-mid); letter-spacing: .5px; }
.load-more-count strong { color: var(--black); }

/* ===== PAGINATION ===== */
.pagination-wrap { display: flex; align-items: center; justify-content: center; gap: 5px; padding: 24px 16px 48px; flex-wrap: wrap; }
.pag-btn { font-family: var(--font-head); font-size: 12px; font-weight: 700; letter-spacing: 1px; padding: 8px 13px; background: var(--white); border: 1.5px solid var(--border); color: var(--gray-dark); min-width: 38px; text-align: center; line-height: 1; transition: var(--ease); display: inline-block; }
.pag-btn:hover { border-color: var(--black); color: var(--black); }
.pag-btn.active { background: var(--black); border-color: var(--black); color: white; }
.pag-btn[disabled] { opacity: .3; cursor: not-allowed; pointer-events: none; }
.pag-info { font-size: 11px; color: var(--gray-mid); letter-spacing: .5px; padding: 0 4px; white-space: nowrap; }

/* ===== FRANCHISE GRID ===== */
.franchise-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; padding: 20px 14px 64px; max-width: 1400px; margin: 0 auto; }
@media (min-width: 540px)  { .franchise-grid { grid-template-columns: repeat(3,1fr); gap: 16px; } }
@media (min-width: 900px)  { .franchise-grid { grid-template-columns: repeat(4,1fr); gap: 20px; padding: 20px 24px 72px; } }
@media (min-width: 1200px) { .franchise-grid { grid-template-columns: repeat(5,1fr); } }
.fc-wrap { display: block; animation: cardIn 0.3s ease forwards; opacity: 0; filter: drop-shadow(0 2px 8px rgba(0,0,0,.10)); transition: filter 0.28s ease, transform 0.28s ease; }
.fc-wrap:hover { filter: drop-shadow(0 8px 24px rgba(0,0,0,.22)); transform: translateY(-5px); }
.fc-card { --cut: 20px; clip-path: polygon(0 0, calc(100% - var(--cut)) 0, 100% var(--cut), 100% 100%, var(--cut) 100%, 0 calc(100% - var(--cut))); overflow: hidden; display: flex; flex-direction: column; background: var(--white); position: relative; }
.fc-image { position: relative; aspect-ratio: 2/3; overflow: hidden; flex-shrink: 0; background: #ebebeb; }
.fc-image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.48s cubic-bezier(.25,.46,.45,.94); }
.fc-wrap:hover .fc-image img { transform: scale(1.08); }
.fc-placeholder { position: absolute; inset: 0; display: none; align-items: center; justify-content: center; background: linear-gradient(145deg,#f0f0f0,#e6e6e6); color: #ccc; font-size: 28px; }

/* Card especial "Todos" — fundo preto com quadrado branco */
.fc-all-cover { position: absolute; inset: 0; background: var(--black); display: flex; align-items: center; justify-content: center; }
.fc-all-cover::before { content:''; position:absolute; inset:0; background: radial-gradient(circle at center, rgba(217,25,31,.25), transparent 60%); pointer-events:none; }
.fc-all-square { width: 42%; aspect-ratio: 1/1; background: var(--white); position: relative; transition: transform .48s cubic-bezier(.25,.46,.45,.94); box-shadow: 0 0 0 4px rgba(255,255,255,.08), 0 18px 50px rgba(0,0,0,.6); }
.fc-all-square::before { content:''; position:absolute; inset:14%; border:2px solid var(--black); }
.fc-wrap--all:hover .fc-all-square { transform: scale(1.08) rotate(-3deg); }
.fc-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 50px 13px 46px; background: linear-gradient(to top, rgba(0,0,0,.82) 0%, rgba(0,0,0,.4) 55%, transparent 100%); pointer-events: none; z-index: 1; }
.fc-name { font-family: var(--font-head); font-size: clamp(14px,2.5vw,18px); font-weight: 800; text-transform: uppercase; letter-spacing: .5px; color: white; line-height: 1.05; margin-bottom: 4px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.fc-count { font-family: var(--font-head); font-size: 10px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,.55); }
.fc-btn { width: 100%; background: var(--red); color: white; font-family: var(--font-head); font-size: 12px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 11px 14px; border: none; display: flex; align-items: center; justify-content: center; gap: 7px; transition: background 0.2s ease; flex-shrink: 0; position: relative; z-index: 2; }
.fc-wrap:hover .fc-btn { background: var(--red-hover); }

/* ===== PÁGINA DO PRODUTO ===== */
.product-page { max-width: 1240px; margin: 0 auto; padding-bottom: 80px; }
.product-breadcrumb { padding: 14px 20px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; font-size: 11px; color: var(--gray-mid); background: var(--white); border-bottom: 1px solid var(--border); }
.product-breadcrumb a { color: var(--gray-mid); transition: color .18s; }
.product-breadcrumb a:hover { color: var(--red); }
.product-breadcrumb span { color: var(--black); font-weight: 600; }
.product-breadcrumb i { font-size: 8px; color: var(--border); }
.product-layout { display: flex; flex-direction: column; }
@media (min-width: 900px) { .product-layout { flex-direction: row; align-items: flex-start; } }
.product-gallery-col { width: 100%; flex-shrink: 0; }
@media (min-width: 900px) { .product-gallery-col { width: 50%; position: sticky; top: var(--header-h); height: calc(100vh - var(--header-h)); display: flex; flex-direction: column; overflow: hidden; } }
.gallery-main { position: relative; overflow: hidden; background: var(--white); aspect-ratio: 1/1; user-select: none; flex-shrink: 0; }
@media (min-width: 900px) { .gallery-main { flex: 1; aspect-ratio: unset; min-height: 0; } }
.gallery-main-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: opacity .2s ease; display: block; }
.gallery-fb { position: absolute; inset: 0; display: none; flex-direction: column; align-items: center; justify-content: center; background: var(--gray-light); color: var(--gray-mid); gap: 10px; }
.gallery-fb i { font-size: 44px; }
.gallery-fb span { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; }
.gallery-arrow { position: absolute; top: 50%; z-index: 10; transform: translateY(-50%); background: rgba(255,255,255,.92); border: none; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; font-size: 13px; color: var(--black); transition: var(--ease); box-shadow: 0 2px 10px rgba(0,0,0,.14); }
.gallery-arrow:hover { background: var(--red); color: white; }
.gallery-arrow:active { transform: translateY(-50%) scale(.93); }
.gallery-arrow.prev { left: 10px; }
.gallery-arrow.next { right: 10px; }
.gallery-arrow:disabled { opacity: .2; pointer-events: none; }
.gallery-counter { position: absolute; bottom: 10px; right: 10px; background: rgba(0,0,0,.5); color: white; font-family: var(--font-head); font-size: 11px; font-weight: 600; letter-spacing: 1px; padding: 3px 9px; pointer-events: none; }
.gallery-thumbs { display: flex; gap: 5px; padding: 8px 12px; overflow-x: auto; scrollbar-width: none; background: var(--white); border-top: 1px solid var(--border); flex-shrink: 0; }
.gallery-thumbs::-webkit-scrollbar { display: none; }
.gallery-thumb { width: 52px; height: 52px; flex-shrink: 0; border: 2px solid transparent; overflow: hidden; transition: border-color .18s; background: var(--gray-light); cursor: pointer; }
.gallery-thumb.active { border-color: var(--red); }
.gallery-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.product-info-col { width: 100%; background: var(--white); }
@media (min-width: 900px) { .product-info-col { width: 50%; border-left: 1px solid var(--border); } }
.pinfo-section { padding: 20px 24px; border-bottom: 1px solid var(--border); }
.pinfo-section:last-child { border-bottom: none; }
.product-badges { display: flex; gap: 5px; flex-wrap: wrap; padding: 16px 24px 0; }
.product-series { font-size: 9.5px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--gray-mid); margin-bottom: 6px; }
.product-name-big { font-family: var(--font-head); font-size: clamp(26px, 4vw, 36px); font-weight: 800; line-height: .95; letter-spacing: -.5px; text-transform: uppercase; margin-bottom: 14px; }
.product-meta-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.studio-chip { display: inline-flex; align-items: center; gap: 6px; background: var(--gray-light); padding: 5px 10px; font-size: 9.5px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gray-dark); }
.franchise-chip { display: inline-flex; align-items: center; gap: 6px; background: var(--black); color: rgba(255,255,255,.7); padding: 5px 10px; font-size: 9.5px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; }
.price-row { display: flex; align-items: baseline; gap: 10px; margin-bottom: 16px; }
.price-label { font-size: 10px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--gray-mid); }
.price-big { font-family: var(--font-head); font-size: 38px; font-weight: 800; color: var(--red); line-height: 1; }
.payment-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.payment-item { background: var(--bg); padding: 12px 14px; border-top: 3px solid transparent; }
.payment-item.entrada { border-color: var(--red); }
.payment-item.entrega { border-color: var(--black); }
.pay-label { font-size: 8.5px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gray-mid); margin-bottom: 3px; }
.pay-pct { font-size: 10px; color: var(--gray-mid); margin-bottom: 4px; }
.pay-value { font-family: var(--font-head); font-size: 20px; font-weight: 700; color: var(--black); line-height: 1; }
.avista-badge { display: inline-flex; align-items: center; gap: 6px; background: var(--green); color: white; font-family: var(--font-head); font-size: 9px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; padding: 6px 14px; }
.block-label { font-size: 9px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--gray-mid); margin-bottom: 12px; }
.specs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--border); border: 1px solid var(--border); }
.spec-item { background: var(--white); padding: 12px 14px; }
.spec-label { font-size: 8.5px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gray-mid); margin-bottom: 4px; }
.spec-value { font-family: var(--font-head); font-size: 15px; font-weight: 700; color: var(--black); }
.desc-text { font-size: 13.5px; line-height: 1.78; color: var(--gray-dark); }
.product-cta-desktop { display: none; }
@media (min-width: 900px) { .product-cta-desktop { display: block; } }
.btn-whatsapp { width: 100%; background: var(--green); color: white; font-family: var(--font-head); font-size: 15px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 15px; border: none; transition: var(--ease); display: flex; align-items: center; justify-content: center; gap: 10px; }
.btn-whatsapp:hover { background: var(--green-h); }
.cta-note { text-align: center; margin-top: 10px; font-size: 11px; color: var(--gray-mid); line-height: 1.6; }
.sticky-cta { position: fixed; bottom: 0; left: 0; right: 0; background: var(--white); border-top: 1px solid var(--border); padding: 9px 14px; z-index: 80; display: flex; align-items: center; gap: 14px; box-shadow: 0 -4px 20px rgba(0,0,0,.06); }
@media (min-width: 900px) { .sticky-cta { display: none; } }
.sticky-price-label { font-size: 9px; color: var(--gray-mid); font-weight: 600; letter-spacing: 1px; text-transform: uppercase; }
.sticky-price-val { font-family: var(--font-head); font-size: 21px; font-weight: 800; color: var(--black); line-height: 1; }
.btn-reserve { flex: 1; background: var(--green); color: white; font-family: var(--font-head); font-size: 14px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; padding: 13px 18px; border: none; transition: var(--ease); display: flex; align-items: center; justify-content: center; gap: 8px; }
.btn-reserve:hover { background: var(--green-h); }
.product-spacer { height: 68px; }
@media (min-width: 900px) { .product-spacer { display: none; } }

/* ===== MODAL DE PAGAMENTO ===== */
.pay-modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.55); z-index: 500; display: flex; align-items: flex-end; justify-content: center; opacity: 0; pointer-events: none; transition: opacity .25s ease; }
@media (min-width: 600px) { .pay-modal-overlay { align-items: center; } }
.pay-modal-overlay.open { opacity: 1; pointer-events: all; }
.pay-modal { background: var(--white); width: 100%; max-width: 480px; max-height: 90dvh; overflow-y: auto; transform: translateY(30px); transition: transform .25s cubic-bezier(.4,0,.2,1); }
.pay-modal-overlay.open .pay-modal { transform: translateY(0); }
.pay-modal-head { display: flex; align-items: center; justify-content: space-between; padding: 16px 18px; border-bottom: 1px solid var(--border); position: sticky; top: 0; background: var(--white); z-index: 2; }
.pay-modal-title { font-family: var(--font-head); font-size: 17px; font-weight: 800; letter-spacing: .5px; text-transform: uppercase; }
.pay-modal-close { background: none; border: none; font-size: 19px; color: var(--black); cursor: pointer; padding: 4px; transition: color .18s; }
.pay-modal-close:hover { color: var(--red); }
.pay-modal-body { padding: 18px; }
.pay-methods { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 18px; }
.pay-method-btn { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 14px 8px; border: 2px solid var(--border); background: var(--white); cursor: pointer; transition: border-color .18s, background .18s; font-family: var(--font-head); font-size: 12px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; color: var(--gray-dark); }
.pay-method-btn i { font-size: 22px; color: var(--gray-mid); transition: color .18s; }
.pay-method-btn.active { border-color: var(--red); background: #fff8f8; color: var(--black); }
.pay-method-btn.active i { color: var(--red); }
.pay-method-btn:hover { border-color: #aaa; }
.pay-panel { display: none; }
.pay-panel.active { display: block; }
.pay-installment-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 6px; margin-top: 10px; }
.pay-inst-btn { padding: 10px 6px; border: 1.5px solid var(--border); background: var(--bg); font-family: var(--font-head); font-size: 13px; font-weight: 700; cursor: pointer; text-align: center; transition: border-color .18s, background .18s; }
.pay-inst-btn:hover { border-color: #aaa; background: var(--white); }
.pay-inst-btn.selected { border-color: var(--red); background: #fff8f8; color: var(--red); }
.pay-inst-val { font-size: 10px; color: var(--gray-mid); display: block; margin-top: 2px; }
.pay-summary { background: var(--bg); border: 1px solid var(--border); padding: 14px; margin-top: 16px; }
.pay-summary-row { display: flex; justify-content: space-between; font-size: 13px; margin-bottom: 4px; }
.pay-summary-row.total { font-family: var(--font-head); font-size: 18px; font-weight: 800; border-top: 1px solid var(--border); padding-top: 8px; margin-top: 6px; }

/* Caixa de juros (mostrada quando seleciona parcela com juros) */
.pay-juros-info { margin-top: 12px; padding: 12px 14px; background: #fff8f8; border: 1px solid #f0c0c2; border-left: 3px solid var(--red); font-size: 12px; }
.pay-juros-line { display: flex; justify-content: space-between; align-items: center; padding: 4px 0; color: var(--gray-dark); }
.pay-juros-line strong { color: var(--black); font-family: var(--font-head); font-size: 13px; }
.pay-juros-line.total { border-top: 1px dashed #f0c0c2; padding-top: 8px; margin-top: 4px; font-weight: 700; color: var(--black); }
.pay-juros-line.total strong { font-size: 15px; color: var(--red); }
.btn-pay-confirm { width: 100%; background: var(--green); color: white; font-family: var(--font-head); font-size: 15px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 14px; border: none; transition: var(--ease); display: flex; align-items: center; justify-content: center; gap: 10px; margin-top: 14px; }
.btn-pay-confirm:hover { background: var(--green-h); }
.btn-pay-confirm:disabled { opacity: .5; cursor: not-allowed; }

/* ===== TCG GUIDE ===== */
.tcg-condition-box { border: 1.5px solid var(--yellow); background: #fffbea; padding: 12px 14px; margin-bottom: 12px; }
.tcg-condition-label-main { font-family: var(--font-head); font-size: 16px; font-weight: 800; color: var(--black); display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.tcg-condition-label-main .cond-badge { background: var(--yellow); color: var(--black); font-size: 11px; font-weight: 800; padding: 2px 8px; font-family: var(--font-head); }
.tcg-condition-desc { font-size: 12px; color: var(--gray-dark); line-height: 1.65; }
.tcg-guide-toggle { display: flex; align-items: center; gap: 7px; font-size: 11px; color: var(--gray-mid); cursor: pointer; margin-top: 10px; padding-top: 10px; border-top: 1px solid #f0e6a0; user-select: none; background: none; border-left: none; border-right: none; border-bottom: none; width: 100%; text-align: left; font-family: var(--font-body); }
.tcg-guide-toggle i { transition: transform .2s; }
.tcg-guide-toggle.open i.chevron { transform: rotate(180deg); }
.tcg-guide-list { display: none; flex-direction: column; gap: 5px; margin-top: 10px; }
.tcg-guide-list.open { display: flex; }
.tcg-guide-row { display: flex; gap: 8px; align-items: flex-start; padding: 7px 10px; background: var(--white); border: 1px solid var(--border); }
.tcg-guide-row.current { background: #fff3cd; border-color: var(--yellow); }
.tcg-guide-sigla { font-family: var(--font-head); font-size: 11px; font-weight: 800; padding: 2px 7px; background: var(--gray-light); white-space: nowrap; flex-shrink: 0; margin-top: 1px; }
.tcg-guide-row.current .tcg-guide-sigla { background: var(--yellow); }
.tcg-guide-text-name { font-family: var(--font-head); font-size: 12px; font-weight: 700; color: var(--black); }
.tcg-guide-text-desc { font-size: 11px; color: var(--gray-dark); line-height: 1.5; margin-top: 1px; }

/* ===== SEARCH PAGE ===== */
.search-hero { background: var(--black); padding: 36px 16px 32px; text-align: center; position: relative; }
.search-hero::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent, var(--red), transparent); }
.search-hero h1 { font-family: var(--font-head); font-size: clamp(32px,9vw,56px); font-weight: 800; text-transform: uppercase; color: var(--white); margin-bottom: 18px; }
.search-hero-form { display: flex; max-width: 560px; margin: 0 auto; }
.search-hero-input { flex: 1; padding: 13px 16px; border: none; background: var(--white); font-family: var(--font-body); font-size: 14px; color: var(--black); outline: none; border-radius: 0; -webkit-appearance: none; }
.search-hero-btn { background: var(--red); color: white; border: none; padding: 13px 22px; font-family: var(--font-head); font-size: 13px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; display: flex; align-items: center; gap: 7px; transition: var(--ease); white-space: nowrap; }
.search-hero-btn:hover { background: var(--red-hover); }
.search-wrap { max-width: 1400px; margin: 0 auto; padding: 24px 16px 60px; }
.search-results-info { padding: 0 0 16px; font-size: 13px; color: var(--gray-mid); }
.search-results-info strong { color: var(--black); }

/* ===== LOGIN ===== */
.login-wrap { min-height: calc(100dvh - var(--header-h)); display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 28px 16px 48px; }
.login-card { background: var(--white); width: 100%; max-width: 380px; padding: 40px 28px; border: 1px solid var(--border); }
.login-logo { font-family: var(--font-brand); font-size: 38px; letter-spacing: 3px; color: var(--black); text-align: center; line-height: 1; }
.login-logo span { color: var(--red); }
.login-logo-sub { text-align: center; font-family: var(--font-head); font-size: 8.5px; font-weight: 600; letter-spacing: 3.5px; color: var(--gray-mid); text-transform: uppercase; margin-bottom: 6px; }
.login-admin-label { display: flex; align-items: center; justify-content: center; gap: 7px; background: var(--black); color: white; font-family: var(--font-head); font-size: 9px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 5px 14px; margin: 0 auto 28px; width: fit-content; }
.login-admin-label i { font-size: 9px; color: var(--yellow); }
.btn-full { width: 100%; background: var(--red); color: white; font-family: var(--font-head); font-size: 15px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 14px; border: none; transition: var(--ease); display: flex; align-items: center; justify-content: center; gap: 9px; }
.btn-full:hover { background: var(--red-hover); }
.btn-full:disabled { opacity: .65; cursor: not-allowed; }
.input-wrap { position: relative; }
.input-eye { position: absolute; right: 11px; top: 50%; transform: translateY(-50%); background: none; border: none; color: var(--gray-mid); font-size: 14px; transition: var(--ease); padding: 4px; }
.input-eye:hover { color: var(--black); }
.login-help { text-align: center; margin-top: 20px; font-size: 11px; color: var(--gray-mid); line-height: 1.6; }
.form-group { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; }
.form-label { font-size: 9.5px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gray-dark); }
.form-input { width: 100%; padding: 11px 13px; border: 1.5px solid var(--border); background: var(--bg); font-family: var(--font-body); font-size: 14px; color: var(--black); transition: var(--ease); outline: none; -webkit-appearance: none; border-radius: 0; }
.form-input:focus { border-color: var(--red); background: var(--white); }
.form-input::placeholder { color: #c0c0c0; }

/* ===== CART DRAWER ===== */
.overlay { position: fixed; inset: 0; background: rgba(0,0,0,.42); z-index: 200; opacity: 0; pointer-events: none; transition: opacity .28s ease; }
.overlay.open { opacity: 1; pointer-events: all; }
.cart-drawer { position: fixed; top: 0; right: -105%; width: 100%; max-width: 350px; height: 100dvh; background: var(--white); z-index: 300; transition: right 0.3s cubic-bezier(.4,0,.2,1); display: flex; flex-direction: column; }
.cart-drawer.open { right: 0; }
.drawer-header { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
.drawer-title { font-family: var(--font-head); font-size: 17px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; }
.close-btn { background: none; border: none; font-size: 19px; color: var(--black); padding: 4px; transition: var(--ease); }
.close-btn:hover { color: var(--red); }
.cart-body { flex: 1; overflow-y: auto; display: flex; flex-direction: column; }
.cart-empty { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; color: var(--gray-mid); gap: 12px; padding: 40px; text-align: center; }
.cart-empty i { font-size: 40px; opacity: .4; }
.cart-empty p { font-size: 14px; }
.cart-items { flex: 1; overflow-y: auto; }
.cart-item { display: flex; gap: 11px; padding: 13px 15px; border-bottom: 1px solid var(--border); align-items: flex-start; }
.cart-item-img { width: 58px; height: 58px; object-fit: cover; background: var(--gray-light); flex-shrink: 0; display: block; }
.cart-item-info { flex: 1; min-width: 0; }
.cart-item-name { font-family: var(--font-head); font-size: 12px; font-weight: 700; text-transform: uppercase; margin-bottom: 2px; }
.cart-item-price { font-size: 12px; color: var(--red); font-weight: 600; }
.cart-item-qty { font-size: 10px; color: var(--gray-mid); margin-top: 2px; }
.cart-item-remove { background: none; border: none; color: var(--gray-mid); font-size: 14px; padding: 2px; transition: var(--ease); flex-shrink: 0; }
.cart-item-remove:hover { color: var(--red); }
.cart-footer { padding: 14px 16px; border-top: 1px solid var(--border); flex-shrink: 0; }
.cart-total-row { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 11px; }
.cart-total-label { font-size: 9.5px; color: var(--gray-mid); text-transform: uppercase; letter-spacing: 1px; font-weight: 600; }
.cart-total-value { font-family: var(--font-head); font-size: 19px; font-weight: 700; color: var(--red); }

/* ===== TOAST ===== */
.toast { position: fixed; bottom: 0; left: 50%; transform: translateX(-50%) translateY(calc(100% + 20px)); background: var(--black); color: white; font-family: var(--font-head); font-size: 12px; font-weight: 600; letter-spacing: .8px; padding: 11px 22px; z-index: 9999; transition: transform 0.3s cubic-bezier(.34,1.4,.64,1); white-space: nowrap; display: flex; align-items: center; gap: 8px; pointer-events: none; box-shadow: var(--shadow-md); }
.toast.show { transform: translateX(-50%) translateY(calc(-68px - 80px)); }
@media (min-width: 900px) { .toast { bottom: 28px; transform: translateX(-50%) translateY(120px); } .toast.show { transform: translateX(-50%) translateY(0); } }
.toast-icon { color: var(--red); }

/* ===== FOOTER ===== */
.footer { background: var(--black); margin-top: 64px; }
@media (min-width: 768px) { .footer { margin-top: 96px; } }
.footer-inner { display: grid; grid-template-columns: 1fr; gap: 32px; padding: 48px 24px 40px; max-width: 1400px; margin: 0 auto; }
@media (min-width: 540px)  { .footer-inner { grid-template-columns: 1fr 1fr; gap: 36px; } }
@media (min-width: 900px)  { .footer-inner { grid-template-columns: 1fr 1fr 1fr 1fr; gap: 48px; } }
@media (min-width: 1200px) { .footer-inner { grid-template-columns: 2fr 1fr 1.4fr 1fr; } }
.footer-logo { font-family: var(--font-brand); font-size: 32px; letter-spacing: 3px; color: var(--white); line-height: 1; margin-bottom: 2px; }
.footer-logo span { color: var(--red); }
.footer-logo-sub { font-family: var(--font-head); font-size: 8px; font-weight: 600; letter-spacing: 3.5px; color: #444; text-transform: uppercase; margin-bottom: 14px; }
.footer-tagline { font-size: 12px; color: #555; line-height: 1.7; }
.footer-col-title { font-family: var(--font-head); font-size: 9px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: #555; margin-bottom: 14px; }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: 9px; }
.footer-links a { font-size: 13px; color: #888; transition: color .18s ease; }
.footer-links a:hover { color: var(--white); }
.footer-contact-link { display: flex; align-items: center; gap: 9px; font-size: 13px; color: #888; transition: color .18s ease; }
.footer-contact-link i { font-size: 15px; color: #555; transition: color .18s ease; flex-shrink: 0; }
.footer-contact-link:hover { color: var(--white); }
.footer-contact-link:hover i { color: var(--green); }
.footer-socials { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 4px; }
.footer-social-btn { width: 40px; height: 40px; background: #1a1a1a; border: 1px solid #2a2a2a; display: flex; align-items: center; justify-content: center; font-size: 17px; color: #666; transition: var(--ease); }
.footer-social-btn--ig:hover { background: #E1306C; color: white; border-color: #E1306C; }
.footer-social-btn--wa:hover { background: var(--green); color: white; border-color: var(--green); }
.footer-legal { border-top: 1px solid #1e1e1e; padding: 18px 24px 6px; max-width: 1400px; margin: 0 auto; text-align: center; }
.footer-legal-company { font-family: var(--font-head); font-size: 12px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: #777; margin-bottom: 4px; }
.footer-legal-cnpj { font-size: 11px; color: #555; letter-spacing: .3px; font-family: monospace; }
.footer-bottom { padding: 14px 24px 22px; font-size: 11px; color: #3a3a3a; letter-spacing: .3px; display: flex; align-items: center; justify-content: center; gap: 10px; flex-wrap: wrap; text-align: center; }
.footer-bottom-sep { color: #2a2a2a; }

/* ===== HOME — DESTAQUES + CATEGORY CARDS ===== */

/* Hero Carousel */
.home-hero-section { padding: 28px 0 0; max-width: 1400px; margin: 0 auto; }
.home-hero-head { padding: 0 16px 14px; display: flex; align-items: center; }
.home-hero-label { font-family: var(--font-head); font-size: 13px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: var(--black); display: flex; align-items: center; gap: 8px; }
.home-hero-carousel-wrap { position: relative; padding: 0 16px 24px; }
#hero-track { display: flex; gap: 14px; overflow-x: auto; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
#hero-track::-webkit-scrollbar { display: none; }
.hero-card { flex: 0 0 158px; scroll-snap-align: start; display: flex; flex-direction: column; background: var(--white); border: 1px solid var(--border); overflow: hidden; transition: var(--ease); color: inherit; text-decoration: none; clip-path: polygon(0 0, calc(100% - 14px) 0, 100% 14px, 100% 100%, 0 100%); }
.hero-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: #ccc; }
@media (min-width: 480px)  { .hero-card { flex: 0 0 178px; } }
@media (min-width: 768px)  { .hero-card { flex: 0 0 198px; } }
@media (min-width: 1024px) { .hero-card { flex: 0 0 218px; } }
.hero-card-img { position: relative; aspect-ratio: 3/4; background: var(--gray-light); overflow: hidden; }
.hero-card-img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease; }
.hero-card:hover .hero-card-img img { transform: scale(1.06); }
.hero-card-img-fb { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; color: #ccc; font-size: 28px; }
.hero-card-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 24px 8px 8px; background: linear-gradient(to top, rgba(0,0,0,.65), transparent); }
.hero-card-type-badge { display: inline-flex; align-items: center; gap: 5px; font-family: var(--font-head); font-size: 9px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; background: var(--red); color: white; padding: 3px 8px; }
.hero-card-body { padding: 9px 10px 11px; flex: 1; display: flex; flex-direction: column; gap: 3px; }
.hero-card-series { font-size: 9px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gray-mid); }
.hero-card-name { font-family: var(--font-head); font-size: 13px; font-weight: 700; text-transform: uppercase; line-height: 1.1; color: var(--black); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.hero-card-price { font-family: var(--font-head); font-size: 14px; font-weight: 700; color: var(--red); margin-top: auto; }
.home-hero-arrow { position: absolute; top: 50%; transform: translateY(-60%); z-index: 10; width: 34px; height: 34px; background: var(--white); border: 1.5px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 11px; color: var(--black); cursor: pointer; transition: var(--ease); box-shadow: var(--shadow-sm); }
.home-hero-arrow:hover { background: var(--black); color: var(--white); border-color: var(--black); }
.home-hero-arrow--prev { left: 0; }
.home-hero-arrow--next { right: 0; }
@media (max-width: 640px) { .home-hero-arrow { display: none; } }

/* Category Cards */
.cat-cards-row { display: grid; grid-template-columns: 1fr; gap: 28px; padding: 28px 16px 8px; max-width: 1400px; margin: 0 auto; }

.cat-card-wrap { position: relative; }
.cat-card-shadow { position: absolute; inset: 0; transform: translate(-7px, 7px); clip-path: polygon(0 0, calc(100% - 22px) 0, 100% 22px, 100% 100%, 22px 100%, 0 calc(100% - 22px)); background: var(--red); pointer-events: none; z-index: 0; }
.cat-card { position: relative; z-index: 1; background: var(--black); clip-path: polygon(0 0, calc(100% - 22px) 0, 100% 22px, 100% 100%, 22px 100%, 0 calc(100% - 22px)); overflow: hidden; }

.cat-card-head { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px 14px; border-bottom: 1px solid rgba(255,255,255,.10); gap: 12px; flex-wrap: wrap; }
.cat-card-title { font-family: var(--font-head); font-size: 22px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; color: var(--white); line-height: 1; }
.cat-card-desc { font-size: 11px; color: rgba(255,255,255,.45); letter-spacing: .5px; margin-top: 2px; }
.cat-card-more { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-head); font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,.5); padding: 5px 10px; border: 1.5px solid rgba(255,255,255,.15); transition: var(--ease); flex-shrink: 0; }
.cat-card-more:hover { color: var(--white); border-color: rgba(255,255,255,.5); }

/*
  CAROUSEL — CSS Container Queries (Chrome 105+, FF 110+, Safari 16+)
  ─────────────────────────────────────────────────────────────────────
  container-type: inline-size  →  .cat-card-carousel-wrap torna-se
  o container de referência. Dentro dele, 100cqi = largura do seu
  content box (sem padding). Sem ambiguidade, sem JS, sempre correto.

  Fallback para browsers antigos: 160px fixo (mostra ≈ 2-4 cards).
*/
.cat-card-carousel-wrap {
  padding: 14px;
  overflow: hidden;
  container-type: inline-size;   /* ← establece o container */
}

.cat-card-track {
  display: flex;
  flex-wrap: nowrap;
  gap: 10px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.cat-card-track::-webkit-scrollbar { display: none; }

/* Fallback: browsers sem container queries */
.cat-card-track .product-card {
  flex: 0 0 160px;
  animation: none;
  opacity: 1;
}

/* Telas muito estreitas: 2 cards */
@container (max-width: 299px) {
  .cat-card-track .product-card {
    flex: 0 0 calc((100cqi - 10px) / 2);
  }
}

/* 3 cards visíveis */
@container (min-width: 300px) {
  .cat-card-track .product-card {
    flex: 0 0 calc((100cqi - 20px) / 3);
  }
}

/* 4 cards */
@container (min-width: 480px) {
  .cat-card-track .product-card {
    flex: 0 0 calc((100cqi - 30px) / 4);
  }
}

/* 5 cards */
@container (min-width: 640px) {
  .cat-card-track .product-card {
    flex: 0 0 calc((100cqi - 40px) / 5);
  }
}

/* 6 cards */
@container (min-width: 800px) {
  .cat-card-track .product-card {
    flex: 0 0 calc((100cqi - 50px) / 6);
  }
}

/* 7 cards */
@container (min-width: 1000px) {
  .cat-card-track .product-card {
    flex: 0 0 calc((100cqi - 60px) / 7);
  }
}

/* 8 cards — desktops largos com cat-card em largura cheia */
@container (min-width: 1200px) {
  .cat-card-track .product-card {
    flex: 0 0 calc((100cqi - 70px) / 8);
  }
}

/* Divider */
.cat-divider { display: flex; align-items: center; margin: 36px auto 0; padding: 0 16px; max-width: 1400px; }
.cat-divider::before, .cat-divider::after { content: ''; flex: 1; height: 1px; background: linear-gradient(90deg, transparent, var(--border) 40%, var(--border) 60%, transparent); }
.cat-divider span { font-family: var(--font-head); font-size: 10px; font-weight: 700; letter-spacing: 3.5px; text-transform: uppercase; color: var(--gray-mid); padding: 0 16px; white-space: nowrap; }
.cat-divider span::before, .cat-divider span::after { content: ''; display: inline-block; width: 4px; height: 4px; background: var(--red); vertical-align: middle; margin: 0 8px; margin-bottom: 1px; }

/* ===== TERMOS E POLÍTICAS (produto) ===== */
.product-termos-wrap { max-width: 1240px; margin: 48px auto 0; padding: 0 20px 40px; }
.termos-header { display: flex; align-items: center; gap: 8px; font-family: var(--font-head); font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--gray-mid); margin-bottom: 12px; }
.termos-header i { color: var(--red); font-size: 12px; }
.termos-preview-box { border: 1px solid var(--border); background: var(--white); }
.termos-preview { position: relative; max-height: 90px; overflow: hidden; padding: 18px 20px 0; font-size: 13px; line-height: 1.85; color: #444; transition: max-height .45s cubic-bezier(.4,0,.2,1); }
.termos-preview.expanded { max-height: 9999px; }
.termos-fade { position: absolute; bottom: 0; left: 0; right: 0; height: 52px; background: linear-gradient(to bottom, transparent, var(--white, #fff)); pointer-events: none; transition: opacity .3s ease; }
.termos-ver-mais { width: 100%; padding: 11px 20px; background: none; border: none; border-top: 1px solid var(--border); font-family: var(--font-head); font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--red); cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 7px; transition: background .18s; }
.termos-ver-mais:hover { background: #fdf5f5; }

/* ===== DETALHES DA PEÇA ===== */
.piece-details-text { background: #fff8f6; border-left: 3px solid #c0392b; padding: 10px 14px; font-size: 13px; line-height: 1.8; color: #555; }

/* ===== MISC ===== */
@media (max-width: 360px) { .logo-top { font-size: 20px; } .logo-sub { font-size: 7px; letter-spacing: 2px; } }
@keyframes pulse { 0%,100%{opacity:1;}50%{opacity:.45;} }