/* ── Gestor Store — Front CSS v3.0.0 ──────────────────────────────────── */

:root {
    /* MUDANÇA v2.0.0: cores primárias alteradas de azul (#2563eb) para vermelho (#c0392b) */
    --gs-primary:      var(--gestor-primary, #c0392b);
    --gs-primary-dark: var(--gestor-primary-dark, #96281b);
    --gs-radius:       var(--gestor-radius, 10px);
    --gs-text:         var(--gestor-text, #1a1f36);
    --gs-muted:        var(--gestor-muted, #6b7280);
    --gs-border:       var(--gestor-border, #e5e7eb);
    --gs-bg:           var(--gestor-bg-card, #ffffff);
    --gs-bg-light:     var(--gestor-bg-light, #f9fafb);

    /* Checkout clássico cinza/vermelho */
    --gs-ck-red:       #c0392b;
    --gs-ck-red-dark:  #96281b;
    --gs-ck-red-light: #fdf2f0;
    --gs-ck-gray:      #f4f5f7;
    --gs-ck-gray-mid:  #dde1e7;
    --gs-ck-text:      #1d2327;
    --gs-ck-muted:     #6c757d;
}

/* ══════════════════════════════════════════════════════════
   NAVEGAÇÃO / TABS
══════════════════════════════════════════════════════════ */
.gs-store-nav {
    display: flex;
    gap: 4px;
    border-bottom: 2px solid var(--gs-border);
    margin-bottom: 24px;
}

.gs-tab-btn {
    padding: 9px 18px;
    border: none;
    background: transparent;
    color: var(--gs-muted);
    cursor: pointer;
    font-weight: 600;
    font-size: 14px;
    text-decoration: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: color .18s, border-color .18s;
    border-radius: 6px 6px 0 0;
}

.gs-tab-btn:hover { color: var(--gs-primary); }

.gs-tab-btn.active,
.gs-tab-btn:focus-visible {
    color: var(--gs-primary);
    border-bottom-color: var(--gs-primary);
    outline: none;
    background: rgba(192,57,43,.05);
}

/* ══════════════════════════════════════════════════════════
   FILTROS — CAIXA MODERNIZADA
══════════════════════════════════════════════════════════ */
.gs-store-filters {
    margin-bottom: 24px;
}

.gs-filters-box {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    background: #ffffff;
    border: 1px solid var(--gs-border);
    border-radius: 12px;
    padding: 14px 18px;
    box-shadow: 0 1px 6px rgba(0,0,0,.05);
}

.gs-filter-group {
    display: flex;
    align-items: center;
    gap: 6px;
}

.gs-filter-label {
    font-size: 12px;
    font-weight: 700;
    color: var(--gs-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    white-space: nowrap;
}

.gs-filter-select {
    appearance: none;
    -webkit-appearance: none;
    padding: 8px 32px 8px 12px;
    border: 1.5px solid var(--gs-border);
    border-radius: 8px;
    font-size: 13px;
    font-weight: 500;
    color: var(--gs-text);
    background: var(--gs-bg-light) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 10px center;
    cursor: pointer;
    transition: border-color .15s, box-shadow .15s;
    min-width: 130px;
}

.gs-filter-select:focus {
    outline: none;
    border-color: var(--gs-primary);
    box-shadow: 0 0 0 3px rgba(192,57,43,.1);
}

.gs-filter-search-wrap {
    position: relative;
    flex: 1;
    min-width: 180px;
}

.gs-filter-search-wrap svg {
    position: absolute;
    left: 11px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--gs-muted);
    pointer-events: none;
}

.gs-filter-search {
    width: 100%;
    padding: 8px 12px 8px 34px;
    border: 1.5px solid var(--gs-border);
    border-radius: 8px;
    font-size: 13px;
    color: var(--gs-text);
    background: var(--gs-bg-light);
    box-sizing: border-box;
    transition: border-color .15s, box-shadow .15s;
}

.gs-filter-search:focus {
    outline: none;
    border-color: var(--gs-primary);
    box-shadow: 0 0 0 3px rgba(192,57,43,.1);
    background: #fff;
}

.gs-filter-search::placeholder { color: #b0b8c4; }

.gs-filter-divider {
    width: 1px;
    height: 28px;
    background: var(--gs-border);
    flex-shrink: 0;
}

.gs-filter-actions {
    display: flex;
    gap: 8px;
    margin-left: auto;
}

.gs-filter-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    border: none;
    cursor: pointer;
    transition: all .15s;
    text-decoration: none;
    white-space: nowrap;
}

.gs-filter-btn--primary {
    background: var(--gs-primary);
    color: #fff;
}
.gs-filter-btn--primary:hover { background: var(--gs-primary-dark); color: #fff; }

.gs-filter-btn--ghost {
    background: transparent;
    color: var(--gs-muted);
    border: 1.5px solid var(--gs-border);
}
.gs-filter-btn--ghost:hover { background: var(--gs-bg-light); color: var(--gs-text); }

.gs-filter-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 10px;
}

.gs-filter-tag {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 10px;
    background: rgba(192,57,43,.08);
    color: var(--gs-primary);
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
}

.gs-filter-tag-remove {
    cursor: pointer;
    font-size: 14px;
    line-height: 1;
    opacity: .6;
}
.gs-filter-tag-remove:hover { opacity: 1; }

/* ══════════════════════════════════════════════════════════
   GRID DE PRODUTOS — LAYOUT PROFISSIONAL v2.0.0
══════════════════════════════════════════════════════════ */
.gs-store-grid-wrapper {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.gs-product-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 22px;
}

.gs-product-card {
    background: #fff;
    border: 1px solid #eaecf0;
    border-radius: 14px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: transform .22s cubic-bezier(.25,.46,.45,.94),
                box-shadow .22s cubic-bezier(.25,.46,.45,.94);
    box-shadow: 0 2px 8px rgba(0,0,0,.05);
    position: relative;
}

.gs-product-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 32px rgba(0,0,0,.11);
    border-color: #d4d8e1;
}

/* Thumbnail */
.gs-product-thumb {
    height: 160px;
    overflow: hidden;
    background: linear-gradient(135deg, #fff0ee 0%, #fde8e5 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.gs-product-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .3s;
}

.gs-product-card:hover .gs-product-thumb img {
    transform: scale(1.04);
}

.gs-product-thumb--placeholder {
    font-size: 52px;
    color: #f5c6c0;
}

/* Badge tipo — posicionado sobre a imagem */
.gs-product-type-badge {
    position: absolute;
    top: 10px;
    left: 10px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    padding: 3px 9px;
    border-radius: 20px;
    backdrop-filter: blur(4px);
    box-shadow: 0 1px 4px rgba(0,0,0,.12);
}

/* v2.0.0: badge digital em vermelho claro (antes era azul) */
.gs-type-digital   { background: rgba(253,226,222,.92); color: #96281b; }
.gs-type-physical  { background: rgba(209,250,229,.92); color: #065f46; }
.gs-type-affiliate { background: rgba(237,233,254,.92); color: #5b21b6; }

/* Corpo do card */
.gs-product-body {
    padding: 16px 16px 10px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 7px;
}

.gs-product-name {
    font-size: 15px;
    font-weight: 700;
    color: #1a1f36;
    margin: 0;
    line-height: 1.35;
}

.gs-product-desc {
    font-size: 13px;
    color: #6b7280;
    margin: 0;
    line-height: 1.5;
}

/* Preço */
.gs-product-price-wrap {
    display: flex;
    align-items: baseline;
    gap: 4px;
    margin-top: auto;
    padding-top: 6px;
}

.gs-product-price-label {
    font-size: 11px;
    font-weight: 600;
    color: #9ca3af;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.gs-product-price {
    font-size: 20px;
    font-weight: 800;
    color: var(--gs-primary);
    margin: 0;
    line-height: 1;
}

/* Rodapé do card */
.gs-product-footer {
    padding: 12px 16px 16px;
}

/* ── Botões principais ─────────────────────────────────────────────── */
.gs-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    width: 100%;
    padding: 10px 18px;
    border: none;
    border-radius: 9px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: all .18s;
    letter-spacing: .01em;
}

/* v2.0.0: botão comprar agora em vermelho (antes era azul) */
.gs-btn-buy {
    background: linear-gradient(135deg, var(--gs-primary) 0%, var(--gs-primary-dark) 100%);
    color: #fff;
    box-shadow: 0 3px 10px rgba(192,57,43,.28);
}
.gs-btn-buy:hover {
    box-shadow: 0 5px 18px rgba(192,57,43,.38);
    transform: translateY(-1px);
}
.gs-btn-buy:active { transform: translateY(0); }

.gs-btn-affiliate {
    background: linear-gradient(135deg, #7c3aed 0%, #5b21b6 100%);
    color: #fff;
    box-shadow: 0 3px 10px rgba(124,58,237,.25);
}
.gs-btn-affiliate:hover { box-shadow: 0 5px 18px rgba(124,58,237,.38); transform: translateY(-1px); }

/* v2.0.0: botão "Saiba mais" (parceiros) em vermelho — idêntico ao gs-btn-buy para não revelar afiliado */
.gs-btn-saiba-mais {
    background: linear-gradient(135deg, var(--gs-primary) 0%, var(--gs-primary-dark) 100%);
    color: #fff;
    box-shadow: 0 3px 10px rgba(192,57,43,.25);
}
.gs-btn-saiba-mais:hover { box-shadow: 0 5px 18px rgba(192,57,43,.38); transform: translateY(-1px); }

.gs-btn-access {
    background: linear-gradient(135deg, #059669 0%, #047857 100%);
    color: #fff;
    box-shadow: 0 3px 10px rgba(5,150,105,.25);
}
.gs-btn-access:hover { box-shadow: 0 5px 18px rgba(5,150,105,.38); transform: translateY(-1px); }

.gs-btn-sm { width: auto; padding: 7px 16px; font-size: 13px; }
.gs-btn:disabled { opacity: .55; cursor: not-allowed; transform: none !important; }

/* ── Produto já adquirido ──────────────────────────────────────────── */
.gs-product-card--owned {
    border-color: #a7f3d0;
    box-shadow: 0 2px 8px rgba(5,150,105,.1);
}
.gs-product-granted, .gs-product-expires {
    display: block;
    font-size: 12px;
    color: var(--gs-muted);
}

/* ── Tabela de pedidos ─────────────────────────────────────────────── */
.gs-orders-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}
.gs-orders-table th,
.gs-orders-table td {
    padding: 11px 14px;
    border-bottom: 1px solid var(--gs-border);
    text-align: left;
}
.gs-orders-table th {
    font-weight: 700;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--gs-muted);
    background: var(--gs-bg-light);
}
.gs-orders-table tbody tr:hover { background: #fafbfc; }

/* ── Badges ─────────────────────────────────────────────────────────── */
.gs-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 700;
}
.gs-badge--active   { background: #d1fae5; color: #065f46; }
.gs-badge--inactive { background: #fee2e2; color: #991b1b; }
.gs-badge--pending  { background: #fef3c7; color: #92400e; }

.gs-empty {
    color: var(--gs-muted);
    text-align: center;
    padding: 60px 0;
    font-size: 15px;
}

/* ══════════════════════════════════════════════════════════
   MODAL OVERLAY
══════════════════════════════════════════════════════════ */
.gs-modal {
    position: fixed;
    inset: 0;
    background: rgba(10,14,30,.5);
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(3px);
}

/* ══════════════════════════════════════════════════════════
   CHECKOUT RÁPIDO — MODELO CLÁSSICO CINZA / VERMELHO
══════════════════════════════════════════════════════════ */
.gs-modal-content { position: relative; }

.gs-modal-pix {
    max-width: 490px;
    width: 94%;
    padding: 0;
    max-height: 94vh;
    overflow-y: auto;
    border-radius: 12px;
    box-shadow: 0 28px 72px rgba(0,0,0,.28), 0 4px 16px rgba(0,0,0,.12);
    background: var(--gs-ck-gray);
    scrollbar-width: thin;
    scrollbar-color: #ccd0d8 transparent;
}

.gs-modal-pix::-webkit-scrollbar { width: 5px; }
.gs-modal-pix::-webkit-scrollbar-thumb { background: #ccd0d8; border-radius: 3px; }

/* ── Cabeçalho Clássico (cinza escuro + vermelho) ──────────────── */
.gs-modal-pix .gs-modal-header {
    background: linear-gradient(135deg, #2d3142 0%, #1d2130 100%);
    padding: 18px 22px 16px;
    border-radius: 12px 12px 0 0;
    position: relative;
    border-bottom: 3px solid var(--gs-ck-red);
}

.gs-modal-pix .gs-modal-close {
    position: absolute;
    top: 12px; right: 14px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.18);
    font-size: 15px;
    cursor: pointer;
    color: rgba(255,255,255,.85);
    width: 28px;
    height: 28px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .15s;
    line-height: 1;
    padding: 0;
}
.gs-modal-pix .gs-modal-close:hover {
    background: rgba(255,255,255,.22);
    color: #fff;
}

.gs-modal-title {
    font-size: 17px;
    font-weight: 800;
    margin: 0 0 3px;
    color: #fff;
    display: flex;
    align-items: center;
    gap: 8px;
    letter-spacing: .01em;
}

.gs-modal-subtitle {
    font-size: 12px;
    color: rgba(255,255,255,.6);
    margin: 0;
    font-weight: 500;
}

/* ── Corpo ─────────────────────────────────────────────────────── */
.gs-modal-body {
    padding: 20px 22px 18px;
    background: var(--gs-ck-gray);
}

/* ── Produto resumo — barra vermelha à esquerda ────────────────── */
.gs-checkout-produto {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #fff;
    border: 1px solid var(--gs-ck-gray-mid);
    border-left: 4px solid var(--gs-ck-red);
    border-radius: 8px;
    padding: 11px 14px;
    margin-bottom: 18px;
    gap: 8px;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
}

.gs-checkout-produto strong {
    font-size: 13px;
    color: var(--gs-ck-text);
    font-weight: 700;
}

.gs-checkout-preco {
    font-size: 17px;
    font-weight: 800;
    color: var(--gs-ck-red);
    white-space: nowrap;
}

/* ── Formulário ────────────────────────────────────────────────── */
.gs-checkout-form {
    display: flex;
    flex-direction: column;
    gap: 13px;
}

.gs-form-section-title {
    font-size: 11px;
    font-weight: 800;
    color: var(--gs-ck-muted);
    text-transform: uppercase;
    letter-spacing: .06em;
    margin: 0 0 -4px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.gs-form-section-title::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--gs-ck-gray-mid);
}

.gs-form-row { display: flex; flex-direction: column; gap: 5px; }

.gs-form-row--2col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 11px;
}

.gs-form-row label {
    font-size: 11px;
    font-weight: 700;
    color: var(--gs-ck-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
}

.gs-form-row label small { font-weight: 400; color: var(--gs-ck-muted); text-transform: none; letter-spacing: 0; }

.gs-form-input {
    padding: 9px 12px;
    border: 1.5px solid var(--gs-ck-gray-mid);
    border-radius: 7px;
    font-size: 14px;
    color: var(--gs-ck-text);
    background: #fff;
    width: 100%;
    box-sizing: border-box;
    transition: border-color .15s, box-shadow .15s;
    line-height: 1.4;
}

.gs-form-input:focus {
    outline: none;
    border-color: var(--gs-ck-red);
    box-shadow: 0 0 0 3px rgba(192,57,43,.1);
}

.gs-form-input::placeholder { color: #c0c7d0; }
textarea.gs-form-input { resize: vertical; min-height: 54px; font-family: inherit; }

/* ── Quantidade ────────────────────────────────────────────────── */
.gs-qty-control {
    display: flex;
    align-items: center;
    width: 112px;
    border: 1.5px solid var(--gs-ck-gray-mid);
    border-radius: 7px;
    overflow: hidden;
    background: #fff;
}

.gs-qty-btn {
    width: 36px;
    height: 38px;
    border: none;
    background: #f4f5f7;
    color: var(--gs-ck-text);
    font-size: 18px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .1s;
    flex-shrink: 0;
    font-weight: 700;
}

.gs-qty-btn:hover { background: #e8eaed; }

.gs-qty-input {
    flex: 1;
    border: none;
    text-align: center;
    font-size: 15px;
    font-weight: 700;
    padding: 0;
    min-width: 0;
    height: 38px;
    color: var(--gs-ck-text);
    background: #fff;
}
.gs-qty-input:focus { outline: none; }
.gs-qty-input::-webkit-inner-spin-button,
.gs-qty-input::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
.gs-qty-input[type=number] { -moz-appearance: textfield; }

/* ── Total ─────────────────────────────────────────────────────── */
.gs-checkout-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 13px 16px;
    background: #fff;
    border: 1.5px solid var(--gs-ck-gray-mid);
    border-radius: 8px;
    font-size: 13px;
    font-weight: 700;
    color: var(--gs-ck-muted);
    margin-top: 2px;
    box-shadow: 0 1px 4px rgba(0,0,0,.04);
}

.gs-checkout-total strong {
    font-size: 24px;
    font-weight: 900;
    color: var(--gs-ck-red);
}

/* ── Ações do modal ────────────────────────────────────────────── */
.gs-modal-actions {
    display: flex;
    gap: 10px;
    margin-top: 18px;
}

.gs-modal-actions .gs-btn-cancel {
    background: #fff;
    color: var(--gs-ck-muted);
    border: 1.5px solid var(--gs-ck-gray-mid);
    border-radius: 8px;
    padding: 10px 18px;
    font-weight: 700;
    transition: all .15s;
    font-size: 14px;
    width: auto;
    flex-shrink: 0;
}
.gs-modal-actions .gs-btn-cancel:hover {
    background: var(--gs-ck-gray-mid);
    color: var(--gs-ck-text);
}

/* ── Botão Gerar PIX — vermelho clássico ───────────────────────── */
.gs-btn-gerar-pix {
    background: linear-gradient(135deg, var(--gs-ck-red) 0%, var(--gs-ck-red-dark) 100%);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-size: 15px;
    font-weight: 800;
    flex: 1;
    border-radius: 8px;
    padding: 11px 20px;
    box-shadow: 0 4px 14px rgba(192,57,43,.38);
    transition: all .18s;
    letter-spacing: .02em;
    border: none;
    cursor: pointer;
}

.gs-btn-gerar-pix:hover {
    background: linear-gradient(135deg, #d94334 0%, var(--gs-ck-red) 100%);
    box-shadow: 0 6px 20px rgba(192,57,43,.48);
    transform: translateY(-1px);
}
.gs-btn-gerar-pix:active { transform: translateY(0); }
.gs-btn-gerar-pix:disabled {
    opacity: .6;
    cursor: not-allowed;
    transform: none !important;
}
.gs-pix-icon { flex-shrink: 0; }

/* ══════════════════════════════════════════════════════════
   PIX — TELA DE PAGAMENTO (header verde)
══════════════════════════════════════════════════════════ */
#gs-step-pix .gs-modal-header {
    background: linear-gradient(135deg, #1a7a50 0%, #145c3c 100%) !important;
    border-bottom-color: #00b272 !important;
}

/* ── Loading ───────────────────────────────────────────────────── */
.gs-pix-loading {
    display: flex !important;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 50px 20px;
    gap: 18px;
    min-height: 220px;
    background: var(--gs-ck-gray);
    border-radius: 0 0 12px 12px;
}

.gs-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid var(--gs-ck-gray-mid);
    border-top-color: var(--gs-ck-red);
    border-radius: 50%;
    animation: gs-spin .7s linear infinite;
}

@keyframes gs-spin { to { transform: rotate(360deg); } }

.gs-pix-loading p {
    font-size: 14px;
    font-weight: 600;
    color: var(--gs-ck-muted);
    margin: 0;
    animation: gs-blink 1.4s ease infinite;
}

@keyframes gs-blink {
    0%, 100% { opacity: 1; }
    50%       { opacity: .45; }
}

/* ── Status Badge PIX ──────────────────────────────────────────── */
.gs-pix-status-badge {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 8px 18px;
    border-radius: 24px;
    font-size: 13px;
    font-weight: 700;
    margin-bottom: 16px;
    background: #fef9e7;
    color: #b45309;
    border: 1px solid #fde68a;
    transition: background .4s, color .4s;
    text-align: center;
}

.gs-pix-status-dot {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: currentColor;
    animation: gs-pulse 1.2s ease infinite;
    flex-shrink: 0;
}

.gs-pix-status--waiting { background: #fef9e7; color: #b45309; border: 1px solid #fde68a; }
.gs-pix-status--paid    { background: #d1fae5; color: #065f46; border: 1px solid #6ee7b7; }
.gs-pix-status--expired { background: #fee2e2; color: #991b1b; border: 1px solid #fca5a5; }
.gs-pix-status--paid .gs-pix-status-dot { animation: none; }

@keyframes gs-pulse {
    0%, 100% { opacity: 1; }
    50%       { opacity: .3; }
}

/* ── QR Code ───────────────────────────────────────────────────── */
.gs-pix-qrcode-wrap {
    text-align: center;
    margin-bottom: 16px;
    padding: 16px;
    background: #fff;
    border-radius: 10px;
    border: 1px solid var(--gs-ck-gray-mid);
    box-shadow: 0 1px 4px rgba(0,0,0,.04);
}

.gs-pix-qrcode-img {
    width: 186px;
    height: 186px;
    border-radius: 6px;
    display: block;
    margin: 0 auto 10px;
    image-rendering: pixelated;
}

.gs-pix-valor-label {
    font-size: 13px;
    color: var(--gs-ck-muted);
    margin: 4px 0 0;
    font-weight: 600;
}
.gs-pix-valor-label strong { color: var(--gs-ck-red); font-size: 18px; }

/* ── Copia e Cola ──────────────────────────────────────────────── */
.gs-pix-copia-wrap { margin-bottom: 13px; }

.gs-pix-copia-label {
    font-size: 11px;
    font-weight: 800;
    color: var(--gs-ck-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin: 0 0 6px;
}

.gs-pix-copia-row {
    display: flex;
    gap: 8px;
    align-items: center;
}

.gs-pix-copia-input {
    flex: 1;
    padding: 9px 11px;
    border: 1.5px solid var(--gs-ck-gray-mid);
    border-radius: 7px;
    font-size: 12px;
    color: var(--gs-ck-muted);
    background: #fff;
    font-family: monospace;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}

.gs-btn-copiar {
    background: var(--gs-ck-red);
    color: #fff;
    white-space: nowrap;
    flex-shrink: 0;
    border-radius: 7px;
    font-weight: 700;
    font-size: 13px;
    padding: 8px 14px;
    border: none;
    cursor: pointer;
    transition: background .15s, box-shadow .15s;
    width: auto;
}
.gs-btn-copiar:hover { background: var(--gs-ck-red-dark); box-shadow: 0 4px 12px rgba(192,57,43,.3); }

.gs-pix-copied-msg {
    font-size: 12px;
    color: #059669;
    font-weight: 700;
    margin: 5px 0 0;
    display: flex;
    align-items: center;
    gap: 4px;
}

/* ── Expiração ─────────────────────────────────────────────────── */
.gs-pix-expiracao-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 7px 14px;
    background: #fff8ee;
    border: 1px solid #fde68a;
    border-radius: 7px;
    margin-bottom: 14px;
    font-size: 12px;
    color: #b45309;
    font-weight: 700;
}

/* ── Sucesso ───────────────────────────────────────────────────── */
.gs-pix-sucesso {
    text-align: center;
    padding: 24px 0 16px;
}

.gs-pix-sucesso-icon {
    font-size: 56px;
    line-height: 1;
    margin-bottom: 14px;
    filter: drop-shadow(0 4px 12px rgba(5,150,105,.25));
}

.gs-pix-sucesso h3 {
    font-size: 20px;
    font-weight: 800;
    color: #065f46;
    margin: 0 0 8px;
}

.gs-pix-sucesso p { font-size: 14px; color: var(--gs-muted); margin: 0; }

/* ── Etapas ────────────────────────────────────────────────────── */
.gs-pix-step { width: 100%; }
.gs-pix-actions { margin-top: 12px; }

/* ── Badge categoria ───────────────────────────────────────────── */
.gs-badge--category {
    background: #ede9fe;
    color: #5b21b6;
    padding: 2px 10px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
}

/* ══════════════════════════════════════════════════════════
   MENSAGEM DE ERRO PIX — v2.0.0
   Garante que o loading nunca fica preso em caso de timeout
══════════════════════════════════════════════════════════ */
.gs-loading-error {
    text-align: center;
    padding: 0 20px 20px;
}

.gs-loading-error p {
    color: #991b1b;
    font-size: 13px;
    font-weight: 600;
    margin: 0 0 12px;
    animation: none !important;
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVO
══════════════════════════════════════════════════════════ */
@media (max-width: 600px) {
    .gs-product-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 14px; }
    .gs-product-thumb { height: 130px; }
    .gs-product-name { font-size: 14px; }
    .gs-product-price { font-size: 17px; }
}

@media (max-width: 480px) {
    .gs-modal-pix { border-radius: 14px 14px 0 0; }
    .gs-modal-body { padding: 16px 16px 14px; }
    .gs-modal-pix .gs-modal-header { padding: 14px 16px 13px; border-radius: 14px 14px 0 0; }
    .gs-pix-qrcode-img { width: 158px; height: 158px; }
    .gs-checkout-produto { flex-direction: column; align-items: flex-start; }
    .gs-form-row--2col { grid-template-columns: 1fr; }
    .gs-modal { align-items: flex-end; }
    .gs-filters-box { flex-direction: column; align-items: stretch; gap: 8px; }
    .gs-filter-actions { margin-left: 0; }
    .gs-filter-divider { display: none; }
}

/* ════════════════════════════════════════════════════════════════════
   MELHORIAS v3.0.0
════════════════════════════════════════════════════════════════════ */

/* ── MELHORIA #2: Load More ────────────────────────────────────── */
.gs-load-more-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 24px 0 8px;
}

.gs-load-more-btn {
    min-width: 200px;
    font-size: 14px !important;
    font-weight: 600 !important;
    padding: 10px 24px !important;
}

/* ── MELHORIA #5: Variações de produto ────────────────────────── */
.gs-product-variations {
    margin-top: 8px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.gs-variation-group { display: flex; flex-direction: column; gap: 4px; }

.gs-variation-label {
    font-size: 11px;
    font-weight: 700;
    color: var(--gs-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
}

.gs-variation-options { display: flex; flex-wrap: wrap; gap: 5px; }

.gs-variation-btn {
    padding: 4px 10px;
    border: 1.5px solid var(--gs-border);
    border-radius: 6px;
    background: #fff;
    font-size: 12px;
    font-weight: 600;
    color: var(--gs-text);
    cursor: pointer;
    transition: all .12s;
}
.gs-variation-btn:hover { border-color: var(--gs-primary); color: var(--gs-primary); }
.gs-variation-btn.gs-variation-selected {
    background: var(--gs-primary);
    border-color: var(--gs-primary);
    color: #fff;
}

/* ── MELHORIA #8: Badge esgotado ───────────────────────────────── */
.gs-badge-esgotado {
    position: absolute;
    top: 10px;
    right: 10px;
    background: rgba(153,27,27,.88);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 3px 9px;
    border-radius: 20px;
    letter-spacing: .04em;
}

.gs-product-card--out-of-stock {
    opacity: .75;
}
.gs-product-card--out-of-stock .gs-product-thumb img {
    filter: grayscale(30%);
}

/* ── MELHORIA #12: Botão avaliar + Modal de avaliação ──────────── */
.gs-btn-review {
    background: transparent;
    border: 1.5px solid var(--gs-border);
    color: var(--gs-muted);
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    padding: 7px 14px;
    cursor: pointer;
    transition: all .15s;
    width: 100%;
    margin-top: 6px;
}
.gs-btn-review:hover { border-color: #fbbf24; color: #b45309; background: #fef9e7; }

.gs-stars-wrap { display: flex; gap: 4px; cursor: pointer; margin: 6px 0; }
.gs-star {
    font-size: 26px;
    color: #d1d5db;
    transition: color .1s;
    line-height: 1;
    user-select: none;
}
.gs-star-active { color: #f59e0b; }

#gs-review-modal .gs-modal-pix { max-width: 420px; }

.gs-review-form { display: flex; flex-direction: column; gap: 12px; }
.gs-review-error {
    color: #991b1b;
    font-size: 13px;
    font-weight: 600;
    padding: 8px 12px;
    background: #fee2e2;
    border-radius: 7px;
}

/* ── MELHORIA #13: Modo Manutenção ─────────────────────────────── */
.gs-maintenance-notice {
    background: #fef9e7;
    border: 1.5px solid #fde68a;
    border-radius: 10px;
    padding: 20px 24px;
    text-align: center;
    color: #92400e;
    font-size: 15px;
    font-weight: 600;
    margin: 24px 0;
}
