:root {
  --bg: #f6f1e7;
  --surface: #fffaf2;
  --line: rgba(38, 31, 23, 0.12);
  --text: #261f17;
  --muted: #786b5f;
  --accent: #bc4b2a;
  --accent-dark: #912f18;
  --success: #1f7a53;
  --shadow: 0 18px 40px rgba(67, 47, 30, 0.12);
  --radius-xl: 28px;
  --radius-lg: 20px;
}
* { box-sizing: border-box; }
body.store-shell {
  margin: 0;
  font-family: "Outfit", sans-serif;
  background:
    radial-gradient(circle at top left, rgba(255,255,255,0.65), transparent 28%),
    linear-gradient(180deg, #f7f3eb 0%, #f0e4d2 100%);
  color: var(--text);
}
a { color: inherit; text-decoration: none; }
.container-fluid { max-width: 1320px; padding-inline: 20px; }
.store-main { min-height: calc(100vh - 160px); }
.store-topbar { display: flex; align-items: center; justify-content: flex-start; gap: 18px; padding-block: 16px; }
.store-topbar-actions { display: flex; align-items: center; gap: 12px; margin-left: 0; flex: 0 0 auto; }
.store-menu-btn-mobile { display: none; flex: 0 0 auto; }
.header-cart-shell { position: relative; }
.store-header { backdrop-filter: blur(16px); background: rgba(246, 241, 231, 0.82); border-bottom: 1px solid var(--line); }
.brand-mark { display: inline-flex; align-items: center; gap: 14px; flex: 0 1 auto; min-width: 0; }
.brand-pill {
  display: inline-grid; place-items: center; width: 48px; height: 48px; border-radius: 16px;
  background: linear-gradient(135deg, var(--accent), #df7c4f); color: #fff; font-weight: 700; box-shadow: var(--shadow);
}
.brand-pill-image { padding: 0; overflow: hidden; background: rgba(255,255,255,.92); }
.brand-pill-image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.brand-logo { max-height: 42px; max-width: 160px; object-fit: contain; display: block; }
.brand-mark small, .text-muted, .meta { color: var(--muted) !important; }
.store-nav { display: flex; gap: 22px; align-items: center; margin-left: auto; margin-right: 6px; justify-content: flex-end; text-align: right; }
.store-nav a, .mobile-nav a { font-weight: 500; color: var(--muted); }
.store-nav a:hover, .mobile-nav a:hover { color: var(--accent-dark); }
.cart-icon-link {
  position: relative; display: inline-grid; place-items: center; width: 48px; height: 48px;
  border-radius: 16px; background: rgba(255,255,255,.88); border: 1px solid var(--line); color: var(--accent-dark);
  box-shadow: var(--shadow);
}
.cart-icon-link svg { width: 24px; height: 24px; fill: currentColor; display: block; }
.header-cart-preview {
   position: absolute;
   top: calc(100% + 12px);
   right: 0;
   width: min(360px, 86vw);
   padding: 16px;
   border-radius: 20px;
   background: rgba(255,255,255,.98);
   border: 1px solid var(--line);
   box-shadow: 0 20px 48px rgba(15,23,42,.18);
   display: grid;
   gap: 14px;
   z-index: 60;
   opacity: 0;
   visibility: hidden;
   pointer-events: none;
   transform: translateY(8px);
   transition: opacity .18s ease, transform .18s ease, visibility .18s ease;
}
.header-cart-shell:hover .header-cart-preview,
.header-cart-shell:focus-within .header-cart-preview,
.header-cart-preview.is-peek {
   opacity: 1;
   visibility: visible;
   pointer-events: auto;
   transform: translateY(0);
}
.header-cart-preview[hidden] {
   display: none !important;
}
.header-cart-preview-head,
.header-cart-preview-total,
.header-cart-preview-item {
   display: flex;
   align-items: center;
   justify-content: space-between;
   gap: 12px;
 }
.header-cart-preview-head a {
   color: var(--accent-dark);
   font-size: .9rem;
   font-weight: 600;
 }
.header-cart-preview-items {
   display: grid;
   gap: 10px;
   max-height: 320px;
   overflow: auto;
 }
.header-cart-preview-item {
   align-items: start;
   padding: 10px 0;
   border-top: 1px solid rgba(38,31,23,.08);
 }
.header-cart-preview-item:first-child {
   border-top: 0;
   padding-top: 0;
 }
.header-cart-preview-item-main {
   display: grid;
   grid-template-columns: 56px 1fr;
   gap: 10px;
   min-width: 0;
   flex: 1 1 auto;
 }
.header-cart-preview-thumb {
   width: 56px;
   height: 56px;
   border-radius: 14px;
   object-fit: cover;
   background: #f6ecdd;
 }
.header-cart-preview-copy {
   display: grid;
   gap: 4px;
   min-width: 0;
 }
.header-cart-preview-copy strong,
.header-cart-preview-copy span {
   display: block;
   overflow: hidden;
   text-overflow: ellipsis;
 }
.header-cart-preview-copy strong {
   font-size: .92rem;
   white-space: nowrap;
 }
.header-cart-preview-copy span {
   color: var(--muted);
   font-size: .82rem;
   white-space: nowrap;
 }
.header-cart-preview-price {
   font-weight: 700;
   white-space: nowrap;
 }
.header-cart-preview-footer {
   display: grid;
   gap: 12px;
   border-top: 1px solid rgba(38,31,23,.08);
   padding-top: 14px;
 }
.cart-icon-badge {
  position: absolute; top: -6px; right: -6px; min-width: 22px; height: 22px; padding-inline: 6px;
  border-radius: 999px; background: var(--accent); color: #fff; font-size: .75rem; font-weight: 700;
  display: inline-grid; place-items: center; border: 2px solid var(--surface); box-shadow: 0 0 0 rgba(188,75,42,.45);
  animation: cartBadgePulse 1.6s ease-in-out infinite;
}
.store-menu-btn { border: 0; background: transparent; width: 44px; height: 44px; display: grid; gap: 5px; padding: 10px; }
.store-menu-btn span { display: block; height: 2px; border-radius: 999px; background: var(--text); }
.mobile-nav { display: grid; gap: 14px; }
.hero-shell, .page-card, .auth-card, .checkout-card, .account-card, .cart-card {
  background: rgba(255, 250, 242, 0.92); border: 1px solid rgba(255,255,255,0.7); box-shadow: var(--shadow); border-radius: var(--radius-xl);
}
.feature-strip-shell {
  margin: 0 0 18px;
}
.feature-strip-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.feature-strip-skeleton {
  display: none;
}
.feature-card {
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  padding: 18px;
  border-radius: 22px;
  background: rgba(255,255,255,.86);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.feature-card-skeleton .feature-card-copy {
  display: grid;
  gap: 8px;
}
.feature-card-skeleton .feature-card-icon {
  background: rgba(120,107,95,.12);
  border: 0;
  box-shadow: none;
}
.feature-card-icon {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  display: inline-grid;
  place-items: center;
  background: linear-gradient(135deg, rgba(188,75,42,.12), rgba(145,47,24,.18));
  color: var(--accent-dark);
}
.feature-card-icon svg {
  width: 24px;
  height: 24px;
  stroke: currentColor;
}
.feature-card-copy {
  min-width: 0;
}
.feature-card-copy strong,
.feature-card-copy span {
  display: block;
}
.feature-card-copy strong {
  font-size: .98rem;
  line-height: 1.25;
}
.feature-card-copy span {
  margin-top: 4px;
  color: var(--muted);
  font-size: .9rem;
  line-height: 1.4;
}
.home-search-shell {
  margin-bottom: 10px;
}
.home-search-box {
  position: relative;
  width: 100%;
}
.home-search-input-skeleton {
  min-height: 54px;
  border-radius: 18px;
  box-shadow: var(--shadow);
  border: 1px solid rgba(255,255,255,.72);
}
.home-search-input {
  min-height: 54px;
  padding-inline: 18px;
  background: rgba(255,255,255,.9);
  box-shadow: var(--shadow);
  border: 1px solid rgba(255,255,255,.72);
}
.home-search-dropdown {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  right: 0;
  z-index: 80;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  padding: 12px;
  background: rgba(255,250,242,.98);
  border: 1px solid var(--line);
  border-radius: 22px;
  box-shadow: 0 22px 55px rgba(15,23,42,.14);
}
.home-search-result {
  display: grid;
  grid-template-columns: 62px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px;
  border-radius: 18px;
  background: rgba(255,255,255,.8);
  border: 1px solid transparent;
  color: inherit;
}
.home-search-result:hover {
  border-color: rgba(188,75,42,.22);
  transform: translateY(-1px);
}
.home-search-result-thumb {
  width: 62px;
  height: 62px;
  border-radius: 16px;
  overflow: hidden;
  background: linear-gradient(135deg, #f4e1d1, #fff8f1);
}
.home-search-result-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.home-search-result-copy {
  min-width: 0;
  display: grid;
  gap: 5px;
}
.home-search-result-copy strong,
.home-search-result-copy span {
  display: block;
}
.home-search-result-copy strong {
  font-size: .98rem;
  line-height: 1.25;
}
.home-search-result-copy span {
  color: var(--muted);
  font-size: .88rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.home-search-result-price {
  font-weight: 700;
  color: var(--accent-dark);
  white-space: nowrap;
}
.home-search-empty,
.home-search-loading {
  padding: 14px 12px;
  color: var(--muted);
  font-size: .94rem;
}
.auth-helper-link {
  display: inline-flex;
  justify-content: flex-end;
  font-size: .94rem;
  font-weight: 600;
  color: var(--accent-dark);
}
.auth-helper-link:hover {
  color: var(--accent);
}
.account-toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}
.account-section-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(320px, .95fr);
  gap: 18px;
}
.account-form-card {
  padding: 22px;
  border-radius: 24px;
  background: rgba(255,255,255,.72);
  border: 1px solid var(--line);
  box-shadow: 0 18px 32px rgba(67,47,30,.08);
}
.account-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.account-grid-span-2 {
  grid-column: 1 / -1;
}
.account-form-actions {
  display: flex;
  justify-content: flex-start;
  gap: 12px;
  margin-top: 18px;
}
.home-section-heading-skeleton {
  display: none;
  gap: 10px;
  margin-bottom: 18px;
}
.home-section-heading-eyebrow {
  width: 92px;
  height: 12px;
  border-radius: 999px;
}
.home-section-heading-title {
  width: 220px;
  height: 24px;
  border-radius: 999px;
}
.hero-shell { position: relative; overflow: hidden; padding: 1px; margin: 2px auto 24px; }
.hero-shell::after {
  content: ""; position: absolute; inset: auto -10% -30% auto; width: 340px; height: 340px; border-radius: 50%;
  background: radial-gradient(circle, rgba(188,75,42,0.18), transparent 70%);
}
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr); gap: 24px; align-items: stretch; }
.eyebrow { text-transform: uppercase; letter-spacing: .16em; font-size: .8rem; color: var(--accent-dark); font-weight: 700; }
.hero-title { font-size: clamp(2.1rem, 4vw, 4.6rem); line-height: .95; margin: 14px 0; }
.hero-copy { color: var(--muted); font-size: 1.05rem; max-width: 58ch; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }
.hero-banner-card {
  position: relative; overflow: hidden; border-radius: 24px; min-height: 260px; aspect-ratio: 21 / 8;
  border: 1px solid rgba(255,255,255,.74); background: linear-gradient(135deg, #f3dfcf, #fff8f0);
  box-shadow: var(--shadow);
}
.hero-skeleton {
  position: absolute;
  inset: 0;
  z-index: 3;
  overflow: hidden;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(243,223,207,.92), rgba(255,248,240,.96));
}
.hero-skeleton::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent);
  transform: translateX(-100%);
  animation: skeleton-shimmer 1.4s infinite;
}
.hero-skeleton-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  padding: 14px;
}
.hero-skeleton-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.hero-skeleton-button {
  width: 168px;
  height: 46px;
  border-radius: 999px;
}
.hero-skeleton-button-alt {
  width: 144px;
}
.hero-skeleton-nav {
  position: absolute;
  top: 50%;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  margin-top: -21px;
  background: rgba(255,255,255,.28);
}
.hero-skeleton-nav-prev {
  left: 18px;
}
.hero-skeleton-nav-next {
  right: 18px;
}
.hero-skeleton-dots {
  position: absolute;
  left: 24px;
  bottom: 18px;
  display: flex;
  gap: 10px;
}
.hero-skeleton-dot {
  width: 11px;
  height: 11px;
  border-radius: 999px;
  background: rgba(255,255,255,.42);
}
.hero-swiper, .hero-swiper .swiper-wrapper, .hero-swiper .swiper-slide { height: 100%; min-height: 260px; }
.hero-slide, .hero-slide-fallback { position: relative; width: 100%; height: 100%; min-height: 260px; overflow: hidden; }
.hero-slide img, .hero-slide-fallback::before {
   width: 100%; height: 100%; object-fit: cover; display: block;
  }
.hero-slide-link {
   display: block;
   width: 100%;
   height: 100%;
 }
.hero-slide-fallback::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.45), transparent 30%),
    linear-gradient(120deg, rgba(23,50,77,.72), rgba(13,142,163,.45)),
    linear-gradient(135deg, #f3dfcf, #fff8f0);
}
.hero-slide::after, .hero-slide-fallback::after {
   content: ""; position: absolute; inset: 0;
   background: transparent;
 }
.hero-slide-overlay {
  position: absolute; inset: 0; z-index: 2; display: flex; align-items: flex-end; justify-content: flex-start;
  padding: 14px;
}
.hero-actions-overlay { margin-top: 0; }
.hero-swiper-pagination.swiper-pagination-bullets {
  position: absolute; left: 24px; bottom: 18px; width: auto; z-index: 4;
}
.hero-swiper-pagination .swiper-pagination-bullet {
  width: 11px; height: 11px; opacity: 1; background: rgba(255,255,255,.54);
}
.hero-swiper-pagination .swiper-pagination-bullet-active {
  background: #fff;
}
.hero-swiper-prev, .hero-swiper-next {
  width: 42px !important; height: 42px !important; border-radius: 999px;
  background: rgba(255,255,255,.2); backdrop-filter: blur(12px);
  color: #fff !important; border: 1px solid rgba(255,255,255,.22);
}
.hero-swiper-prev::after, .hero-swiper-next::after { font-size: 16px !important; font-weight: 700; }
.hero-swiper-prev { left: 18px !important; }
.hero-swiper-next { right: 18px !important; }
.metric-pill, .account-row, .order-card, .cart-item {
   background: rgba(255,255,255,.82); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 14px;
  }
.page-loading-skeleton {
   display: none;
   gap: 16px;
 }
.page-skeleton-eyebrow {
   width: 96px;
   height: 12px;
   border-radius: 999px;
 }
.page-skeleton-title {
   width: min(320px, 82%);
   height: 28px;
   border-radius: 999px;
 }
.page-skeleton-text {
   width: 100%;
   max-width: 460px;
   height: 14px;
   border-radius: 999px;
 }
.page-skeleton-text.short {
   max-width: 220px;
 }
.page-skeleton-price {
   width: 140px;
   height: 24px;
   border-radius: 999px;
 }
.page-skeleton-input {
   width: 100%;
   min-height: 48px;
   border-radius: 14px;
 }
.page-skeleton-textarea {
   width: 100%;
   min-height: 112px;
   border-radius: 18px;
 }
.page-skeleton-button {
   width: 100%;
   max-width: 220px;
   min-height: 46px;
   border-radius: 999px;
 }
.page-skeleton-stack {
   display: grid;
   gap: 12px;
 }
.product-page-skeleton {
   display: none;
   grid-template-columns: minmax(0, 1fr) minmax(340px, 440px);
   gap: 18px;
 }
.product-page-skeleton-media {
   min-height: 560px;
   border-radius: 22px;
 }
.product-page-skeleton-side {
   display: grid;
   gap: 18px;
 }
.cart-page-skeleton,
.checkout-page-skeleton,
.checkout-summary-skeleton {
   display: none;
 }
.cart-item-skeleton {
   pointer-events: none;
 }
.cart-item-skeleton .cart-item-head {
   grid-template-columns: 90px 1fr;
 }
.account-row {
   display: grid;
   gap: 6px;
   align-content: start;
 }
.account-row strong {
   display: block;
 }
.account-row span {
   word-break: break-word;
 }
.order-card-link {
   display: grid;
   gap: 14px;
   color: inherit;
   text-decoration: none;
 }
.order-card-link:hover {
   border-color: rgba(188,75,42,.28);
   transform: translateY(-1px);
 }
.order-card-head {
   display: flex;
   align-items: start;
   justify-content: space-between;
   gap: 12px;
 }
.order-card-head strong,
.order-card-head span {
   display: block;
 }
.order-card-head span {
   color: var(--muted);
   font-size: .92rem;
   margin-top: 4px;
 }
.order-card-meta {
   display: flex;
   align-items: center;
   justify-content: space-between;
   gap: 12px;
   color: var(--muted);
 }
.order-card-meta strong {
   color: var(--text);
   font-size: 1rem;
 }
.order-status-pill {
   display: inline-flex;
   align-items: center;
   justify-content: center;
   padding: 7px 12px;
   border-radius: 999px;
   font-size: .78rem;
   font-weight: 700;
   letter-spacing: .04em;
   text-transform: uppercase;
   white-space: nowrap;
   background: rgba(120,107,95,.12);
   color: var(--muted);
 }
.order-status-pill.is-approved {
   background: rgba(34,197,94,.14);
   color: #166534;
 }
.order-status-pill.is-pending {
   background: rgba(245,158,11,.16);
   color: #9a6700;
 }
.order-status-pill.is-expired {
   background: rgba(239,68,68,.14);
   color: #991b1b;
 }
.order-items-preview {
   display: grid;
   gap: 8px;
   margin: 0;
   padding: 0;
   list-style: none;
 }
.order-items-preview li {
   display: flex;
   align-items: center;
   justify-content: space-between;
   gap: 12px;
   color: var(--text);
   font-size: .95rem;
 }
.order-items-preview li span {
   color: var(--muted);
 }
.order-more-items {
   color: var(--muted);
   font-size: .9rem;
 }
.pix-panel {
   background: rgba(255,255,255,.88);
   border: 1px solid var(--line);
   border-radius: var(--radius-lg);
   padding: 16px;
   display: grid;
   gap: 14px;
 }
.credit-panel {
   background: rgba(255,255,255,.88);
   border: 1px solid var(--line);
   border-radius: var(--radius-lg);
   padding: 16px;
   display: grid;
   gap: 10px;
 }
.credit-panel-head {
   display: grid;
   gap: 4px;
 }
.credit-form-grid {
   display: grid;
   grid-template-columns: repeat(3, minmax(0, 1fr));
   gap: 12px;
 }
.credit-form-grid .full {
   grid-column: 1 / -1;
 }
#creditFeedback.is-valid {
   color: #0f9f6e !important;
 }
#creditFeedback.is-invalid {
   color: #c63b3b !important;
 }
.checkout-payment-methods {
   display: grid;
   gap: 10px;
}
.payment-method-option {
   display: grid;
   grid-template-columns: auto auto 1fr;
   gap: 12px;
   align-items: start;
   padding: 14px 16px;
   border-radius: 18px;
   border: 1px solid var(--line);
   background: rgba(255,255,255,.82);
   cursor: pointer;
   transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease, background .18s ease;
}
.payment-method-option:hover {
   transform: translateY(-1px);
   border-color: rgba(188,75,42,.26);
}
.payment-method-option input {
   margin-top: 3px;
}
.payment-method-icon {
   width: 42px;
   height: 42px;
   border-radius: 14px;
   display: inline-flex;
   align-items: center;
   justify-content: center;
   background: linear-gradient(180deg, rgba(188,75,42,.12), rgba(188,75,42,.2));
   color: var(--accent-dark);
   font-size: .78rem;
   font-weight: 800;
   letter-spacing: .04em;
   border: 1px solid rgba(188,75,42,.16);
}
.payment-method-option:has(input:checked) {
   border-color: rgba(188,75,42,.38);
   box-shadow: 0 0 0 2px rgba(188,75,42,.12);
   background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(188,75,42,.05));
}
.payment-method-option:has(input:checked) strong {
   color: var(--accent-dark);
}
.payment-method-option:has(input:checked) .payment-method-icon {
   background: linear-gradient(180deg, rgba(188,75,42,.2), rgba(188,75,42,.32));
   border-color: rgba(188,75,42,.24);
}
.payment-method-option small {
   display: block;
   color: var(--muted);
   margin-top: 2px;
}
.payment-method-option-test {
   border-style: dashed;
}
.payment-method-option-test .payment-method-icon {
   background: linear-gradient(180deg, rgba(31,122,83,.14), rgba(31,122,83,.22));
   color: var(--success);
   border-color: rgba(31,122,83,.18);
}
.payment-method-option-test:has(input:checked) .payment-method-icon {
   background: linear-gradient(180deg, rgba(31,122,83,.22), rgba(31,122,83,.34));
   border-color: rgba(31,122,83,.24);
}
.checkout-payment-hint {
   padding: 12px 14px;
   border-radius: 14px;
   border: 1px solid rgba(188,75,42,.12);
   background: rgba(255,255,255,.72);
   color: var(--muted);
   font-size: .94rem;
}
.saved-cards-section {
   display: grid;
   gap: 10px;
}
.saved-cards-list {
   display: grid;
   gap: 10px;
}
.saved-card-chip {
   width: 100%;
   text-align: left;
   display: grid;
   gap: 4px;
   padding: 12px 14px;
   border-radius: 16px;
   border: 1px solid var(--line);
   background: rgba(255,255,255,.92);
   color: var(--text);
}
.saved-card-chip.is-active {
   border-color: rgba(188,75,42,.42);
   box-shadow: 0 0 0 2px rgba(188,75,42,.12);
}
.saved-card-chip span {
   color: var(--muted);
   font-size: .92rem;
}
.saved-card-toggle {
   display: flex;
   align-items: center;
   gap: 10px;
   color: var(--text);
   font-size: .95rem;
}
.checkout-modal {
   position: fixed;
   inset: 0;
   z-index: 2100;
   display: grid;
   place-items: center;
   padding: 18px;
}
.checkout-modal-backdrop {
   position: absolute;
   inset: 0;
   background: rgba(15,23,42,.42);
   backdrop-filter: blur(4px);
}
.checkout-modal-card {
   position: relative;
   z-index: 1;
   width: min(100%, 620px);
   max-height: calc(100vh - 36px);
   overflow: auto;
   border-radius: 26px;
   background: rgba(255,255,255,.98);
   box-shadow: 0 24px 70px rgba(15,23,42,.24);
   padding: 18px;
}
.checkout-modal-card-pix {
   width: min(100%, 520px);
}
.checkout-modal-close {
   position: absolute;
   top: 12px;
   right: 14px;
   width: 36px;
   height: 36px;
   border-radius: 999px;
   border: 1px solid var(--line);
   background: rgba(255,255,255,.96);
   color: var(--text);
   font-size: 1.4rem;
   line-height: 1;
}
body.modal-open {
   overflow: hidden;
}
.cookie-consent-banner {
   position: fixed;
   left: 16px;
   right: 16px;
   bottom: 16px;
   z-index: 2050;
   transform: translateY(calc(100% + 24px));
   opacity: 0;
   transition: transform .28s ease, opacity .28s ease;
}
.cookie-consent-banner.is-visible {
   transform: translateY(0);
   opacity: 1;
}
.cookie-consent-card {
   width: min(100%, 980px);
   margin: 0 auto;
   display: grid;
   grid-template-columns: minmax(0, 1fr) auto;
   gap: 18px;
   align-items: center;
   padding: 18px 20px;
   border-radius: 24px;
   background: rgba(19, 23, 31, .96);
   color: #fff;
   box-shadow: 0 20px 60px rgba(15,23,42,.28);
}
.cookie-consent-copy {
   display: grid;
   gap: 8px;
}
.cookie-consent-copy p {
   margin: 0;
   color: rgba(255,255,255,.78);
}
.cookie-consent-links {
   display: flex;
   flex-wrap: wrap;
   gap: 14px;
}
.cookie-consent-links a {
   color: #fff;
   text-decoration: underline;
   text-underline-offset: 3px;
}
.cookie-consent-actions {
   display: flex;
   gap: 10px;
   align-items: center;
}
.cookie-consent-actions .btn-brand-outline {
   color: #fff;
   border-color: rgba(255,255,255,.24);
   background: transparent;
}
.cookie-consent-actions .btn-brand-outline:hover {
   border-color: rgba(255,255,255,.4);
   background: rgba(255,255,255,.08);
}
.pix-panel-head {
   display: flex;
   align-items: start;
   justify-content: space-between;
   gap: 12px;
 }
.pix-status-chip {
   display: inline-flex;
   align-items: center;
   justify-content: center;
   min-width: 48px;
   padding: 6px 10px;
   border-radius: 999px;
   background: rgba(188,75,42,.1);
   color: var(--accent-dark);
   font-size: .72rem;
   font-weight: 700;
   letter-spacing: .08em;
   text-transform: uppercase;
 }
.pix-qr-shell {
   display: flex;
   justify-content: center;
   padding: 10px;
   border-radius: var(--radius-lg);
   background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,241,235,.95));
   border: 1px solid rgba(188,75,42,.12);
 }
.pix-qr-code {
   width: 230px;
   min-height: 230px;
   display: grid;
   place-items: center;
   background: #fff;
   border-radius: 18px;
   padding: 14px;
   box-shadow: inset 0 0 0 1px rgba(16,24,40,.06);
 }
.pix-qr-code img,
.pix-qr-code canvas {
   max-width: 100%;
   height: auto;
 }
.pix-actions {
   display: grid;
 }
.pix-waiting {
   display: flex;
   align-items: center;
   gap: 10px;
   color: var(--muted);
   font-size: .95rem;
 }
.pix-waiting-spinner,
.payment-overlay-spinner {
   width: 18px;
   height: 18px;
   border-radius: 50%;
   border: 2px solid rgba(188,75,42,.22);
   border-top-color: var(--accent);
   animation: spin-ring 1s linear infinite;
 }
.payment-overlay {
   position: fixed;
   inset: 0;
   z-index: 2000;
   display: grid;
   place-items: center;
   padding: 20px;
   background: rgba(15, 23, 42, .28);
   backdrop-filter: blur(6px);
 }
.payment-overlay-card {
   min-width: min(92vw, 360px);
   display: grid;
   justify-items: center;
   gap: 10px;
   padding: 24px 22px;
   border-radius: 26px;
   background: rgba(255,255,255,.97);
   border: 1px solid rgba(255,255,255,.75);
   box-shadow: 0 20px 60px rgba(15,23,42,.18);
   text-align: center;
 }
.payment-overlay-spinner {
   width: 42px;
   height: 42px;
   border-width: 3px;
 }
@keyframes spin-ring {
   to { transform: rotate(360deg); }
 }
  .metric-pill strong { display: block; font-size: 1.4rem; }
.section-shell { padding: 12px 0 30px; }
.section-head { display: flex; align-items: end; justify-content: space-between; gap: 16px; margin: 10px 0 18px; }
.section-head p { color: var(--muted); margin: 0; }
.category-strip, .thumb-strip { display: flex; gap: 12px; overflow-x: auto; padding-bottom: 6px; }
.category-strip-skeleton {
  display: none;
  overflow: hidden;
}
.category-strip {
  scrollbar-width: thin;
  scrollbar-color: rgba(38,31,23,.18) var(--bg);
}
.category-strip::-webkit-scrollbar {
  height: 6px;
}
.category-strip::-webkit-scrollbar-track {
  background: var(--bg);
  border-radius: 999px;
}
.category-strip::-webkit-scrollbar-thumb {
  background: rgba(38,31,23,.18);
  border-radius: 999px;
}
.category-strip::-webkit-scrollbar-thumb:hover {
  background: rgba(38,31,23,.28);
}
.chip-link, .grade-chip {
  white-space: nowrap; border: 1px solid var(--line); background: rgba(255,255,255,.8); color: var(--text);
  border-radius: 999px; padding: 10px 16px; font-weight: 600;
}
.chip-link-media {
  display: inline-flex; align-items: center; gap: 10px; padding: 8px 14px 8px 8px; min-height: 58px;
}
.chip-link-thumb {
  width: 36px; height: 36px; min-width: 36px; min-height: 36px; max-width: 36px; max-height: 36px;
  border-radius: 999px; overflow: hidden; flex: 0 0 36px;
  border: 1px solid var(--line); background: rgba(255,255,255,.92);
}
.chip-link-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.chip-link-text { white-space: nowrap; }
.chip-link-skeleton {
  pointer-events: none;
}
.chip-link-skeleton .chip-link-text {
  display: inline-block;
  width: 112px;
  height: 14px;
  border-radius: 999px;
}
.chip-link-skeleton .chip-link-thumb {
  background: rgba(120,107,95,.12);
}
.grade-chip.active, .grade-chip.is-active { background: var(--accent); color: #fff; border-color: var(--accent); }
.product-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; }
.product-grid-skeleton { margin-top: 18px; display: none; }
.product-card {
  display: flex; flex-direction: column; gap: 14px; padding: 16px; background: rgba(255,255,255,.82);
    border-radius: var(--radius-lg); border: 1px solid var(--line); min-height: 100%;
  }
.product-card-skeleton .product-body { display: grid; gap: 12px; }
.skeleton-block,
.skeleton-line {
   position: relative;
   overflow: hidden;
   background: rgba(120,107,95,.12);
   border-radius: 14px;
 }
.skeleton-block::after,
.skeleton-line::after {
   content: "";
   position: absolute;
   inset: 0;
   transform: translateX(-100%);
   background: linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent);
   animation: skeleton-shimmer 1.3s infinite;
 }
.skeleton-block {
   min-height: 220px;
 }
.skeleton-line {
   height: 14px;
   border-radius: 999px;
 }
.skeleton-line-title { width: 78%; height: 18px; }
.skeleton-line-meta { width: 54%; }
.skeleton-line-price { width: 42%; }
.skeleton-line-button { width: 100%; height: 40px; border-radius: 12px; margin-top: 6px; }
.catalog-loading-more {
   margin-top: 18px;
   text-align: center;
   color: var(--muted);
   font-size: .95rem;
 }
.catalog-sentinel {
   width: 100%;
   height: 1px;
 }
@keyframes skeleton-shimmer {
   100% { transform: translateX(100%); }
 }
.product-card-media-link { display: block; }
.home-collection-shell[hidden] { display: none !important; }
.home-product-swiper {
  padding: 4px 52px 10px;
}
.home-product-swiper[hidden] { display: none !important; }
.home-product-swiper .swiper-slide {
  height: auto;
}
.home-product-slide {
  height: 100%;
}
.home-slider-skeleton {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.home-slider-skeleton[hidden] { display: none !important; }
.home-product-prev,
.home-product-next {
  width: 40px !important;
  height: 40px !important;
  border-radius: 999px;
  background: rgba(255,255,255,.88);
  color: var(--accent-dark) !important;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.home-product-prev::after,
.home-product-next::after {
  font-size: 14px !important;
  font-weight: 700;
}
.home-product-prev { left: 0 !important; }
.home-product-next { right: 0 !important; }
.product-media {
  position: relative; aspect-ratio: 1 / 1.05; border-radius: 16px; overflow: hidden; background: linear-gradient(135deg, #f4e1d1, #fff8f1);
}
.product-media img, .product-media video, .gallery-main img, .gallery-main video, .thumb-strip img, .thumb-strip video {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.product-title { font-size: 1.05rem; font-weight: 600; min-height: 2.8em; }
.price-row, .price-line { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.price-tag { font-size: 1.3rem; font-weight: 700; color: var(--accent-dark); }
.stock-tag { padding: 6px 10px; border-radius: 999px; background: rgba(31,122,83,.12); color: var(--success); font-size: .85rem; font-weight: 600; }
.btn-brand, .btn-brand-outline { border-radius: 999px; padding: 12px 20px; font-weight: 700; }
.btn-brand { border: 0; color: #fff; background: linear-gradient(135deg, var(--accent), #d7683a); }
.btn-brand-outline { border: 1px solid rgba(188,75,42,.25); color: var(--accent-dark); background: rgba(255,255,255,.75); }
.page-shell { padding: 26px 0 40px; }
.page-card, .auth-card, .checkout-card, .account-card, .cart-card { padding: 20px; }
.toolbar-shell, .auth-grid, .hero-grid, .product-detail-grid, .cart-layout, .checkout-layout, .account-layout {
  display: grid; gap: 18px;
}
.toolbar-shell { grid-template-columns: 1.6fr .8fr; margin-bottom: 18px; }
.auth-grid { grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr); align-items: stretch; }
.product-detail-grid { grid-template-columns: minmax(0, 1fr) minmax(340px, 440px); }
.product-detail-grid > div,
.product-detail-grid > aside {
  min-width: 0;
}
.cart-layout, .checkout-layout, .account-layout { grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr); }
.auth-side {
  padding: 24px; border-radius: var(--radius-xl); background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(247,210,195,.75));
  border: 1px solid rgba(188,75,42,.15);
}
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.form-grid .full { grid-column: 1 / -1; }
.form-control, .form-select { min-height: 48px; border-radius: 14px; border-color: rgba(38,31,23,.15); }
.summary-box { position: sticky; top: 96px; display: grid; gap: 16px; height: fit-content; }
.coupon-box {
  display: grid;
  gap: 8px;
}
.coupon-box-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
}
.coupon-feedback {
  min-height: 20px;
}
.coupon-feedback.is-valid {
  color: var(--success) !important;
}
.coupon-feedback.is-invalid {
  color: #b42318 !important;
}
.cashback-box {
  display: grid;
  gap: 8px;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255,255,255,.78);
}
.cashback-box-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.cashback-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  color: var(--accent-dark);
  cursor: pointer;
}
.cashback-toggle input {
  width: 18px;
  height: 18px;
}
.cashback-feedback {
  min-height: 20px;
}
.cashback-feedback.is-valid {
  color: var(--success) !important;
}
.cashback-feedback.is-invalid {
  color: #b42318 !important;
}
.price-line-discount strong {
  color: var(--success);
}
.price-line-cashback strong {
  color: var(--accent-dark);
}
.gallery-main { border-radius: 22px; overflow: hidden; background: rgba(255,255,255,.9); border: 1px solid var(--line); aspect-ratio: 1 / 1; }
.gallery-main {
  width: 100%;
  max-width: 100%;
}
.thumb-strip button { border: 1px solid var(--line); background: rgba(255,255,255,.86); border-radius: 16px; overflow: hidden; width: 78px; height: 78px; padding: 0; flex: 0 0 auto; }
.thumb-item.is-active { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(188,75,42,.18); }
.thumb-video { display: grid; place-items: center; width: 100%; height: 100%; font-weight: 700; color: var(--accent-dark); background: linear-gradient(135deg, #f7d8c8, #fff5ec); }
.grade-swatch { display: inline-block; width: 14px; height: 14px; border-radius: 999px; margin-right: 8px; border: 1px solid rgba(38,31,23,.16); vertical-align: middle; }
.shipping-option {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 14px; border-radius: 18px; border: 1px solid var(--line); background: rgba(255,255,255,.82); cursor: pointer;
}
.shipping-option input { margin-top: 2px; }
.checkout-shipping-provider {
  line-height: 1.5;
}
.checkout-shipping-summary-card {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(188,75,42,.14);
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(247,241,233,.96));
}
.checkout-shipping-summary-card strong,
.checkout-shipping-summary-card span,
.checkout-shipping-summary-card b {
  display: block;
}
.checkout-shipping-summary-card span {
  color: var(--muted);
  font-size: .92rem;
}
.checkout-shipping-summary-card b {
  color: var(--accent-dark);
  font-size: 1rem;
}
.product-shipping-box {
  display: grid;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid rgba(38,31,23,.08);
}
.product-shipping-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
}
.product-shipping-feedback {
  min-height: 20px;
}
.product-shipping-results {
  display: grid;
  gap: 10px;
}
.product-shipping-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.78);
}
.product-shipping-item strong,
.product-shipping-item span {
  display: block;
}
.product-shipping-item span {
  color: var(--muted);
  font-size: .9rem;
  margin-top: 3px;
}
.product-shipping-price {
  font-weight: 700;
  color: var(--accent-dark);
  white-space: nowrap;
}
.theme-preview .btn-brand { background: linear-gradient(135deg, var(--accent), #d7683a); }
.grade-box { display: grid; gap: 10px; margin-top: 14px; }
.grade-chip-row { display: flex; flex-wrap: wrap; gap: 8px; }
.cart-item-head { display: grid; grid-template-columns: 90px 1fr auto; gap: 12px; align-items: center; }
.cart-thumb { width: 90px; height: 90px; border-radius: 18px; object-fit: cover; background: #f6ecdd; }
.empty-state { padding: 40px 20px; text-align: center; color: var(--muted); }
.store-footer { border-top: 1px solid var(--line); padding: 18px 0 30px; }
.footer-grid { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; align-items: flex-start; }
.footer-company { display: grid; gap: 6px; max-width: 760px; }
.footer-company p { color: var(--muted); }
.footer-link { margin-left: 12px; color: var(--accent-dark); font-weight: 600; }
.footer-link:hover { color: var(--accent); }
.footer-meta { display: flex; gap: 14px; flex-wrap: wrap; color: var(--muted); }
@keyframes cartBadgePulse {
  0% { transform: scale(1); box-shadow: 0 0 0 0 rgba(188,75,42,.42); }
  50% { transform: scale(1.08); box-shadow: 0 0 0 8px rgba(188,75,42,0); }
  100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(188,75,42,0); }
}
@media (min-width: 992px) {
  .store-menu-btn { display: none; }
  .store-menu-btn-mobile { display: none !important; }
  .store-topbar { gap: 24px; }
}
@media (max-width: 991px) {
  .hero-grid, .product-detail-grid, .cart-layout, .checkout-layout, .account-layout, .auth-grid, .toolbar-shell { grid-template-columns: 1fr; }
    .summary-box { position: static; }
    .store-nav { display: none; }
    .store-menu-btn-mobile { display: grid; }
    .store-menu-btn-actions { display: none; }
    .store-topbar-actions { margin-left: auto; gap: 0; }
    .header-cart-shell { margin-left: auto; }
    .cart-icon-link { margin-right: -2px; }
    .header-cart-preview { display: none !important; }
    .feature-strip-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .home-slider-skeleton { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .home-product-swiper { padding-inline: 0; }
    .home-product-prev, .home-product-next { display: none !important; }
    .hero-banner-card { min-height: 220px; aspect-ratio: 16 / 8; }
    .product-page-skeleton { grid-template-columns: 1fr; }
    .product-page-skeleton-media { min-height: 380px; }
    .store-topbar { gap: 12px; }
  .hero-banner-card, .hero-swiper, .hero-swiper .swiper-wrapper, .hero-swiper .swiper-slide, .hero-slide, .hero-slide-fallback { min-height: 220px; }
}
@media (max-width: 767px) {
  .container-fluid { padding-inline: 14px; }
  .feature-strip-grid { grid-template-columns: 1fr; }
  .home-search-box { max-width: none; }
  .home-search-result {
    grid-template-columns: 56px minmax(0, 1fr);
  }
  .home-search-result-price {
    grid-column: 2;
  }
  .home-search-dropdown {
    grid-template-columns: 1fr;
  }
  .hero-shell { padding: 1px; border-radius: 22px; }
  .page-card, .auth-card, .checkout-card, .account-card, .cart-card { padding: 12px; border-radius: 22px; }
  .product-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .home-slider-skeleton { grid-template-columns: 1fr; }
  .cart-item-head { grid-template-columns: 74px 1fr; }
  .cart-item-head .btn { grid-column: 1 / -1; width: 100%; }
  .form-grid { grid-template-columns: 1fr; }
  .credit-form-grid { grid-template-columns: 1fr; }
  .coupon-box-row { grid-template-columns: 1fr; }
  .cookie-consent-card { grid-template-columns: 1fr; }
  .cookie-consent-actions { width: 100%; display: grid; }
  .cashback-box-head { align-items: flex-start; flex-direction: column; }
  .account-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
  .account-section-grid,
  .account-form-grid { grid-template-columns: 1fr; }
  .account-grid-span-2 { grid-column: auto; }
  .product-shipping-form,
  .product-shipping-item { grid-template-columns: 1fr; }
  .page-card {
    overflow: hidden;
  }
  .gallery-main {
    border-radius: 18px;
  }
  .thumb-strip {
    width: 100%;
    max-width: 100%;
  }
  .section-head { align-items: start; flex-direction: column; }
    .footer-link { margin-left: 0; display: inline-block; margin-top: 8px; }
    .pix-qr-code {
      width: 200px;
      min-height: 200px;
    }
    .order-card-head,
    .order-card-meta,
    .order-items-preview li {
      align-items: start;
      flex-direction: column;
    }
  .hero-banner-card { min-height: 200px; aspect-ratio: 4 / 3; }
  .hero-banner-card, .hero-swiper, .hero-swiper .swiper-wrapper, .hero-swiper .swiper-slide, .hero-slide, .hero-slide-fallback { min-height: 200px; }
}
@media (max-width: 479px) {
  .product-grid { grid-template-columns: 1fr; }
  .hero-title { font-size: 2.2rem; }
}
