/* ═══════════════════════════════════════════
   GREENY QUOTE MANAGER v2.0 — FRONTEND CSS
   Brand: #B8F612 (primary) | #022A42 (secondary)
═══════════════════════════════════════════ */

/* ── Variables (overrideable from settings) ── */
:root {
    --gqm-primary:    #B8F612;
    --gqm-secondary:  #022A42;
    --gqm-btn-bg:     #B8F612;
    --gqm-btn-text:   #022A42;
    --gqm-font:       'Barlow', sans-serif;
    --gqm-radius:     12px;
    --gqm-radius-sm:  8px;
    --gqm-radius-lg:  16px;
    --gqm-shadow:     0 4px 20px rgba(2,42,66,.10);
    --gqm-shadow-md:  0 8px 32px rgba(2,42,66,.16);
    --gqm-border:     1px solid #e8e8e8;
    --gqm-transition: .22s ease;
}

/* ═══════════════════════════════════════════
   QUOTE BUTTON (on product pages)
═══════════════════════════════════════════ */
.gqm-btn-wrap {
    margin-top: 16px;
    font-family: var(--gqm-font);
}

.gqm-add-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    width: 100% !important;
    padding: 13px 22px !important;
    background: var(--gqm-btn-bg) !important;
    color: var(--gqm-btn-text) !important;
    font-family: var(--gqm-font) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
    border: none !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    transition: all var(--gqm-transition) !important;
    box-shadow: 0 4px 14px rgba(184,246,18,.30) !important;
    position: relative !important;
    overflow: hidden !important;
    outline: none !important;
    text-decoration: none !important;
    line-height: 1.4 !important;
    appearance: none !important;
    -webkit-appearance: none !important;
}
.gqm-add-btn::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,0);
    transition: background var(--gqm-transition);
}
.gqm-add-btn:hover::before { background: rgba(255,255,255,.12); }
.gqm-add-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(184,246,18,.40);
}
.gqm-add-btn:active { transform: translateY(0); }
.gqm-add-btn.gqm-added {
    background: var(--gqm-secondary) !important;
    color: #fff !important;
    box-shadow: none !important;
    border: none !important;
}
.gqm-add-btn svg { flex-shrink: 0; }
.gqm-btn--loop { font-size: 12px; padding: 10px 16px; }

.gqm-view-link {
    display: none;
    text-align: center;
    margin-top: 8px;
    color: var(--gqm-secondary);
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    font-family: var(--gqm-font);
    transition: color var(--gqm-transition);
}
.gqm-view-link.visible { display: block; }
.gqm-view-link:hover { color: rgba(2,42,66,.7); }

.gqm-price-tag {
    font-size: 14px;
    color: #999;
    font-style: italic;
    margin: 0 0 10px;
    font-family: var(--gqm-font);
}

/* ═══════════════════════════════════════════
   FLOATING BUBBLE
═══════════════════════════════════════════ */
.gqm-bubble {
    position: fixed;
    bottom: 28px;
    right: 28px;
    z-index: 9990;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    opacity: 0;
    transform: scale(.75) translateY(16px);
    pointer-events: none;
    transition: opacity .3s, transform .35s cubic-bezier(.34,1.56,.64,1);
}
.gqm-bubble.is-visible {
    opacity: 1;
    transform: scale(1) translateY(0);
    pointer-events: all;
}
.gqm-bubble button {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    border: none;
    background: var(--gqm-secondary);
    color: var(--gqm-primary);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    box-shadow: 0 6px 24px rgba(2,42,66,.38);
    transition: transform var(--gqm-transition), box-shadow var(--gqm-transition);
}
.gqm-bubble button:hover {
    transform: scale(1.1);
    box-shadow: 0 10px 30px rgba(2,42,66,.48);
}
.gqm-bubble-count {
    position: absolute;
    top: -5px;
    right: -5px;
    background: var(--gqm-primary);
    color: var(--gqm-secondary);
    border-radius: 50%;
    width: 22px;
    height: 22px;
    font-size: 11px;
    font-weight: 900;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--gqm-font);
    border: 2px solid #fff;
    line-height: 1;
}
.gqm-bubble-label {
    font-size: 11px;
    font-weight: 700;
    color: var(--gqm-secondary);
    font-family: var(--gqm-font);
    background: #fff;
    padding: 3px 10px;
    border-radius: 20px;
    box-shadow: 0 2px 8px rgba(0,0,0,.1);
}

/* ═══════════════════════════════════════════
   DRAWER OVERLAY
═══════════════════════════════════════════ */
.gqm-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(2,20,42,.55);
    z-index: 9994;
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
}
.gqm-overlay.is-open { display: block; }

/* ═══════════════════════════════════════════
   DRAWER PANEL
═══════════════════════════════════════════ */
.gqm-drawer {
    position: fixed;
    top: 0;
    right: -440px;
    width: 420px;
    max-width: 95vw;
    height: 100dvh;
    background: #fff;
    z-index: 9995;
    display: flex;
    flex-direction: column;
    box-shadow: -8px 0 48px rgba(2,42,66,.20);
    transition: right .35s cubic-bezier(.4,0,.2,1);
}
.gqm-drawer.is-open { right: 0; }

/* Head */
.gqm-drawer__head {
    background: var(--gqm-secondary);
    padding: 18px 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-shrink: 0;
}
.gqm-drawer__title {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #fff;
    font-family: var(--gqm-font);
    font-size: 15px;
    font-weight: 700;
}
.gqm-drawer__close {
    background: none;
    border: none;
    color: rgba(255,255,255,.55);
    font-size: 28px;
    cursor: pointer;
    line-height: 1;
    padding: 0 2px;
    transition: color var(--gqm-transition);
}
.gqm-drawer__close:hover { color: var(--gqm-primary); }

/* Body */
.gqm-drawer__body {
    flex: 1;
    overflow-y: auto;
    padding: 14px;
    scroll-behavior: smooth;
}
.gqm-drawer-items { display: flex; flex-direction: column; gap: 10px; }

/* Foot */
.gqm-drawer__foot {
    padding: 14px 16px;
    border-top: 1px solid #f0f0f0;
    background: #fafafa;
    flex-shrink: 0;
}
.gqm-drawer__summary {
    text-align: center;
    font-size: 13px;
    color: #888;
    font-family: var(--gqm-font);
    margin: 0 0 10px;
}

/* ═══════════════════════════════════════════
   ITEMS (drawer + page)
═══════════════════════════════════════════ */
.gqm-drawer-item,
.gqm-page-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: #f7f8fa;
    border-radius: var(--gqm-radius-sm);
    border: 1px solid #ebebeb;
    transition: background var(--gqm-transition);
}
.gqm-drawer-item:hover,
.gqm-page-item:hover { background: #f0f2f5; }

.gqm-drawer-item__img,
.gqm-page-item__img {
    width: 54px;
    height: 54px;
    object-fit: cover;
    border-radius: 6px;
    flex-shrink: 0;
}
.gqm-drawer-item__img--placeholder,
.gqm-page-item__img--placeholder {
    background: #e8edf2;
}

.gqm-drawer-item__info,
.gqm-page-item__info { flex: 1; min-width: 0; }

.gqm-drawer-item__name,
.gqm-page-item__name {
    font-size: 13px;
    font-weight: 700;
    color: var(--gqm-secondary);
    font-family: var(--gqm-font);
    margin: 0 0 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.gqm-drawer-item__sku,
.gqm-page-item__sku {
    font-size: 11px;
    color: #aaa;
    margin: 0 0 6px;
    font-family: var(--gqm-font);
}

/* Qty control */
.gqm-qty-control {
    display: flex;
    align-items: center;
    gap: 8px;
}
.gqm-qty-btn {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 1.5px solid #ddd;
    background: #fff;
    color: var(--gqm-secondary);
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    transition: all var(--gqm-transition);
}
.gqm-qty-btn:hover {
    background: var(--gqm-secondary);
    color: #fff;
    border-color: var(--gqm-secondary);
}
.gqm-qty-val {
    font-size: 14px;
    font-weight: 700;
    min-width: 22px;
    text-align: center;
    font-family: var(--gqm-font);
    color: var(--gqm-secondary);
}

/* Remove button */
.gqm-drawer-item__remove,
.gqm-page-item__remove {
    background: none;
    border: none;
    color: #ccc;
    cursor: pointer;
    padding: 4px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    transition: color var(--gqm-transition), background var(--gqm-transition);
    flex-shrink: 0;
}
.gqm-drawer-item__remove:hover,
.gqm-page-item__remove:hover {
    color: #e53e3e;
    background: rgba(229,62,62,.08);
}

/* ═══════════════════════════════════════════
   COMMON COMPONENTS
═══════════════════════════════════════════ */

/* Count pill */
.gqm-count-pill {
    background: var(--gqm-primary);
    color: var(--gqm-secondary);
    border-radius: 20px;
    padding: 2px 10px;
    font-size: 11px;
    font-weight: 700;
    font-family: var(--gqm-font);
    margin-left: auto;
}

/* Buttons */
.gqm-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-family: var(--gqm-font);
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
    border: none;
    border-radius: var(--gqm-radius-sm);
    cursor: pointer;
    text-decoration: none;
    transition: all var(--gqm-transition);
    position: relative;
}
.gqm-btn--primary {
    background: var(--gqm-btn-bg);
    color: var(--gqm-btn-text);
    padding: 13px 24px;
    font-size: 14px;
    box-shadow: 0 4px 14px rgba(184,246,18,.30);
}
.gqm-btn--primary:hover {
    filter: brightness(1.08);
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(184,246,18,.42);
    color: var(--gqm-btn-text);
    text-decoration: none;
}
.gqm-btn--primary:active { transform: translateY(0); }
.gqm-btn--primary:disabled {
    opacity: .6;
    cursor: not-allowed;
    transform: none;
}
.gqm-btn--full { width: 100%; }

/* Spinner */
.gqm-spinner {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2.5px solid rgba(2,42,66,.2);
    border-top-color: var(--gqm-btn-text);
    border-radius: 50%;
    animation: gqm-spin .65s linear infinite;
    flex-shrink: 0;
}
@keyframes gqm-spin { to { transform: rotate(360deg); } }

.gqm-btn__loading { display: none; }

/* Empty state */
.gqm-empty-state {
    text-align: center;
    padding: 40px 20px;
    color: #bbb;
    font-size: 14px;
    font-family: var(--gqm-font);
    line-height: 1.6;
}
.gqm-empty-state a {
    color: var(--gqm-secondary);
    font-weight: 600;
    text-decoration: none;
}
.gqm-empty-state a:hover { text-decoration: underline; }

/* Toast */
.gqm-toast {
    position: fixed;
    bottom: 100px;
    right: 28px;
    z-index: 99999;
    background: var(--gqm-secondary);
    color: #fff;
    padding: 12px 20px;
    border-radius: var(--gqm-radius-sm);
    font-family: var(--gqm-font);
    font-size: 14px;
    font-weight: 600;
    border-left: 4px solid var(--gqm-primary);
    box-shadow: var(--gqm-shadow-md);
    max-width: 320px;
    animation: gqm-toast-in .3s ease, gqm-toast-out .3s 2.8s ease forwards;
    pointer-events: none;
}
@keyframes gqm-toast-in  { from { opacity:0; transform:translateX(20px); } to { opacity:1; transform:translateX(0); } }
@keyframes gqm-toast-out { from { opacity:1; } to { opacity:0; } }

/* ═══════════════════════════════════════════
   QUOTE PAGE
═══════════════════════════════════════════ */
.gqm-page {
    max-width: 1080px;
    margin: 0 auto;
    padding: 32px 16px 64px;
    font-family: var(--gqm-font);
}
.gqm-page-header {
    text-align: center;
    margin-bottom: 36px;
}
.gqm-page-header h2 {
    font-size: 28px;
    font-weight: 900;
    color: var(--gqm-secondary);
    margin: 0 0 8px;
    letter-spacing: -.01em;
}
.gqm-page-header p {
    font-size: 16px;
    color: #777;
    margin: 0;
}

/* Layouts */
.gqm-page-body {
    display: grid;
    gap: 24px;
}
.gqm-layout--two-col .gqm-page-body {
    grid-template-columns: 1fr 1fr;
}
.gqm-layout--one-col .gqm-page-body {
    grid-template-columns: 1fr;
    max-width: 640px;
    margin: 0 auto;
}
.gqm-layout--form-only .gqm-page-body {
    grid-template-columns: 1fr;
    max-width: 640px;
    margin: 0 auto;
}

@media (max-width: 768px) {
    .gqm-layout--two-col .gqm-page-body { grid-template-columns: 1fr; }
    .gqm-page-header h2 { font-size: 22px; }
}

/* Card */
.gqm-card {
    background: #fff;
    border-radius: var(--gqm-radius);
    border: var(--gqm-border);
    padding: 24px;
    box-shadow: var(--gqm-shadow);
}
.gqm-card-title {
    font-size: 15px;
    font-weight: 700;
    color: var(--gqm-secondary);
    margin: 0 0 20px;
    padding-bottom: 12px;
    border-bottom: 2px solid var(--gqm-primary);
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--gqm-font);
}

/* Page items */
.gqm-page-items { display: flex; flex-direction: column; gap: 10px; }

/* Form */
.gqm-form { font-family: var(--gqm-font); }
.gqm-form-row { margin-bottom: 0; }
.gqm-form-row--2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 14px;
}
@media (max-width: 540px) { .gqm-form-row--2 { grid-template-columns: 1fr; } }

.gqm-field { margin-bottom: 14px; }
.gqm-field label {
    display: block;
    font-size: 12px;
    font-weight: 700;
    color: var(--gqm-secondary);
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: .05em;
    font-family: var(--gqm-font);
}
.gqm-required { color: #e53e3e; margin-left: 2px; }

.gqm-field input,
.gqm-field select,
.gqm-field textarea {
    display: block;
    width: 100%;
    padding: 11px 14px;
    border: 1.5px solid #e0e0e0;
    border-radius: var(--gqm-radius-sm);
    font-family: var(--gqm-font);
    font-size: 14px;
    color: #333;
    background: #fff;
    transition: border-color var(--gqm-transition), box-shadow var(--gqm-transition);
    box-sizing: border-box;
    appearance: none;
}
.gqm-field select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23666' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
    cursor: pointer;
}
.gqm-field textarea {
    min-height: 90px;
    resize: vertical;
    line-height: 1.5;
}
.gqm-field input:focus,
.gqm-field select:focus,
.gqm-field textarea:focus {
    outline: none;
    border-color: var(--gqm-secondary);
    box-shadow: 0 0 0 3px rgba(2,42,66,.08);
}
.gqm-field input.gqm-error,
.gqm-field select.gqm-error,
.gqm-field textarea.gqm-error {
    border-color: #e53e3e;
    box-shadow: 0 0 0 3px rgba(229,62,62,.10);
}

/* Form notice */
.gqm-form-notice {
    padding: 12px 16px;
    border-radius: var(--gqm-radius-sm);
    font-size: 14px;
    font-weight: 600;
    font-family: var(--gqm-font);
    margin-bottom: 14px;
    display: none;
}
.gqm-form-notice.is-error {
    display: block;
    background: #fff2f2;
    color: #c53030;
    border: 1px solid #fed7d7;
}
.gqm-form-notice.is-success {
    display: block;
    background: #f0fff4;
    color: #276749;
    border: 1px solid #c6f6d5;
}

/* Trust badges */
.gqm-trust-row {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid #f0f0f0;
}
.gqm-trust-item {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    color: #888;
    font-family: var(--gqm-font);
}
.gqm-trust-item svg { color: var(--gqm-secondary); flex-shrink: 0; }

/* ═══════════════════════════════════════════════════
   CART BUBBLE — v2
═══════════════════════════════════════════════════ */
.gsm-bubble{position:fixed;bottom:28px;right:28px;z-index:9999;transition:opacity .2s,transform .2s;opacity:0;pointer-events:none;transform:scale(.9)}
.gsm-bubble.is-visible{opacity:1;pointer-events:all;transform:scale(1)}
.gsm-bubble-btn{width:56px;height:56px;border-radius:50%;background:var(--gsm-s,#022A42);color:var(--gsm-p,#B8F612);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(2,42,66,.35);transition:transform .2s,box-shadow .2s;position:relative}
.gsm-bubble-btn:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(2,42,66,.45)}
.gsm-bubble-count{position:absolute;top:-4px;right:-4px;background:var(--gsm-p,#B8F612);color:var(--gsm-s,#022A42);border-radius:50%;width:20px;height:20px;font-size:11px;font-weight:900;display:flex;align-items:center;justify-content:center;border:2px solid #fff;line-height:1}
@media(max-width:560px){.gsm-bubble{bottom:16px;right:16px}}

/* ═══════════════════════════════════════════════════
   CART DRAWER — v2
═══════════════════════════════════════════════════ */
.gsm-drawer-overlay{display:none!important}
.gsm-drawer-overlay.is-open{display:none!important}
.gsm-drawer{display:none!important}
.gsm-drawer.is-open{display:none!important}
@media(max-width:480px){.gsm-drawer{width:100%}}
.gsm-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid #f0f0f0;flex-shrink:0;background:var(--gsm-s,#022A42);color:#fff}
.gsm-drawer-title{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:700}
.gsm-drawer-count-pill{background:var(--gsm-p,#B8F612);color:var(--gsm-s,#022A42);border-radius:10px;padding:1px 8px;font-size:11px;font-weight:900}
.gsm-drawer-close{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.6);font-size:22px;line-height:1;padding:4px;border-radius:6px;transition:color .15s}
.gsm-drawer-close:hover{color:#fff}
.gsm-drawer-body{flex:1;overflow-y:auto;padding:12px 0;scrollbar-width:thin}
.gsm-drawer-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:#ccc;gap:10px}
.gsm-drawer-empty p{font-size:14px;color:#999;margin:0}
.gsm-drawer-empty small{font-size:12px;color:#ccc}
.gsm-drawer-items{display:flex;flex-direction:column;gap:0}
.gsm-drawer-item{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid #f5f5f5;transition:background .12s}
.gsm-drawer-item:hover{background:#fafafa}
.gsm-drawer-item-img{width:48px;height:48px;border-radius:8px;object-fit:cover;flex-shrink:0;background:#f0f0f0}
.gsm-drawer-item-img--ph{width:48px;height:48px;border-radius:8px;background:#f0f0f0;flex-shrink:0}
.gsm-drawer-item-info{flex:1;min-width:0}
.gsm-drawer-item-name{font-size:13px;font-weight:600;color:var(--gsm-s,#022A42);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;margin:0 0 2px}
.gsm-drawer-item-sku{font-size:11px;color:#aaa;margin:0 0 6px}
.gsm-drawer-qty{display:flex;align-items:center;gap:5px}
.gsm-drawer-qty-btn{width:22px;height:22px;border:1px solid #ddd;background:#f7f7f7;border-radius:5px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .1s;flex-shrink:0}
.gsm-drawer-qty-btn:hover{background:#eee}
.gsm-drawer-qty-val{font-size:13px;font-weight:700;min-width:20px;text-align:center;color:var(--gsm-s,#022A42)}
.gsm-drawer-remove{background:none;border:none;cursor:pointer;color:#ccc;padding:6px;border-radius:6px;display:flex;align-items:center;flex-shrink:0;transition:all .15s}
.gsm-drawer-remove:hover{color:#ef4444;background:#fef2f2}
.gsm-drawer-foot{padding:16px 20px;border-top:1px solid #f0f0f0;flex-shrink:0;background:#fafafa}
.gsm-drawer-summary{font-size:12px;color:#888;margin:0 0 10px;text-align:center}
.gsm-drawer-cta{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 20px;background:var(--gsm-s,#022A42);color:var(--gsm-p,#B8F612);border-radius:10px;text-decoration:none;font-size:15px;font-weight:800;transition:opacity .15s;letter-spacing:-.01em}
.gsm-drawer-cta:hover{opacity:.88}

/* ═══════════════════════════════════════════════════
   SHOP GRID & FILTERS — v2 Professional
═══════════════════════════════════════════════════ */
.gsm-shop{font-family:var(--gsm-font,Barlow,system-ui,sans-serif)}

/* Filter bar */
.gsm-shop-filters{margin-bottom:24px}
.gsm-filter-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;padding:14px 16px;background:#f8f9fa;border-radius:12px;border:1px solid #eee}
.gsm-search-wrap{position:relative!important;flex:1!important;min-width:180px!important}
.gsm-search-icon{position:absolute!important;left:13px!important;top:50%!important;transform:translateY(-50%)!important;color:#aaa!important;pointer-events:none!important;width:16px!important;height:16px!important;flex-shrink:0!important;display:block!important;z-index:1!important}
.gsm-search-input{width:100%!important;padding:9px 32px 9px 42px!important;border:1.5px solid #e5e7eb!important;border-radius:8px!important;font-size:14px!important;outline:none!important;background:#fff!important;transition:border-color .15s!important;font-family:inherit!important;box-sizing:border-box!important}
.gsm-search-input:focus{border-color:var(--gsm-s,#022A42)!important;box-shadow:none!important;outline:none!important}
.gsm-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:#aaa;text-decoration:none;font-size:16px;line-height:1;padding:2px}
.gsm-search-clear:hover{color:#333}
.gsm-select-wrap{position:relative;flex-shrink:0}
.gsm-filter-select{appearance:none;-webkit-appearance:none;padding:9px 32px 9px 12px;border:1.5px solid #e5e7eb;border-radius:8px;font-size:13px;background:#fff;cursor:pointer;font-family:inherit;transition:border-color .15s;color:#444;min-width:140px}
.gsm-filter-select:focus{outline:none;border-color:var(--gsm-s,#022A42)}
.gsm-select-arr{position:absolute;right:10px;top:50%;transform:translateY(-50%);pointer-events:none;color:#888}
.gsm-filter-reset{display:inline-flex;align-items:center;gap:5px;padding:8px 12px;font-size:13px;color:#888;border:1px solid #e5e7eb;border-radius:8px;text-decoration:none;background:#fff;white-space:nowrap;transition:all .15s;font-family:inherit;cursor:pointer;flex-shrink:0}
.gsm-filter-reset:hover{color:#ef4444;border-color:#fca5a5}

.gsm-results-bar{display:flex;align-items:center;gap:10px;margin-top:12px;flex-wrap:wrap}
.gsm-results-count{font-size:13px;color:#888}
.gsm-results-count strong{color:var(--gsm-s,#022A42);font-weight:700}
.gsm-active-tag{display:inline-flex;align-items:center;gap:5px;background:var(--gsm-s,#022A42);color:#fff;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600}
.gsm-active-tag-x{color:rgba(255,255,255,.7);text-decoration:none;font-size:14px;line-height:1}
.gsm-active-tag-x:hover{color:#fff}

/* Grid */
.gsm-grid{display:grid;grid-template-columns:repeat(var(--gsm-cols,3),1fr);gap:24px}
@media(max-width:960px){.gsm-grid{grid-template-columns:1fr!important}}

/* ═══════════════════════════════════════════════════
   PRODUCT CARD — all styles
═══════════════════════════════════════════════════ */
.gsm-product-card{display:flex;flex-direction:column;background:#fff;border-radius:14px;overflow:hidden;border:1px solid #eee;transition:box-shadow .2s,transform .2s;position:relative}
.gsm-card--hover-lift:hover{box-shadow:0 10px 40px rgba(2,42,66,.1);transform:translateY(-3px)}
.gsm-card--hover-zoom:hover .gsm-card-img{transform:scale(1.06)}
.gsm-card--featured{border-color:var(--gsm-p,#B8F612);box-shadow:0 0 0 1px var(--gsm-p,#B8F612)}
.gsm-card--in-cart{border-color:var(--gsm-s,#022A42)}

/* Image wrapper */
.gsm-card-img-wrap{position:relative;overflow:hidden;background:#f8f9fa;flex-shrink:0}
.gsm-card-img-link{display:block;overflow:hidden}
.gsm-card-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s cubic-bezier(.25,.46,.45,.94)}
.gsm-card-in-cart-badge{position:absolute;bottom:10px;left:10px;background:var(--gsm-s,#022A42);color:var(--gsm-p,#B8F612);font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px}

/* Badges */
.gsm-badge{position:absolute;top:10px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:800;letter-spacing:.04em;line-height:1.4;z-index:2}
.gsm-badge--feat{left:10px}
.gsm-badge--promo{left:10px;background:#ef4444;color:#fff}
.gsm-badge--feat ~ .gsm-badge--promo{left:auto;right:10px}

/* Body */
.gsm-card-body{padding:14px 16px;flex:1;display:flex;flex-direction:column;gap:4px}
.gsm-card-cat{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;text-decoration:none;display:block;margin-bottom:2px;line-height:1}
.gsm-card-title{margin:0;line-height:1.25;font-weight:800}
.gsm-card-title a{text-decoration:none;transition:opacity .15s}
.gsm-card-title a:hover{opacity:.7}
.gsm-card-sku{font-size:11px;color:#aaa;margin:0}
.gsm-card-excerpt{font-size:12px;color:#777;margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.gsm-card-rating{display:flex;align-items:center;gap:5px;font-size:12px;color:#888}
.gsm-card-rating-count{font-size:11px}
.gsm-card-price{margin:4px 0 0;display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}
.gsm-price-old{font-size:12px;color:#bbb;text-decoration:line-through}
.gsm-price{font-size:17px;font-weight:900;color:var(--gsm-s,#022A42)}
.gsm-price-unit{font-size:11px;color:#aaa}
.gsm-price-consult{font-size:13px;color:#aaa;font-style:italic;margin:4px 0 0}

/* Footer */
.gsm-card-footer{padding:10px 16px 14px;display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:auto}
.gsm-stock-dot{font-size:12px;font-weight:600;display:flex;align-items:center;gap:5px;white-space:nowrap}
.gsm-stock-dot__dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}

/* Add button */
.gsm-add-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:none;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;transition:opacity .15s,transform .12s,background .2s,color .2s;white-space:nowrap;font-family:inherit;flex-shrink:0;line-height:1.3}
.gsm-add-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}
.gsm-add-btn:active{transform:scale(.97)}
.gsm-add-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.gsm-add-btn--minimal{width:100%;justify-content:center;margin-top:8px;padding:10px}

/* Overlay style */
.gsm-card--overlay{border:none}
.gsm-card--overlay .gsm-card-img-wrap{position:relative;aspect-ratio:4/5}
.gsm-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(2,42,66,.9) 0%,transparent 50%);display:flex;flex-direction:column;justify-content:flex-end;padding:16px;pointer-events:none}
.gsm-card-overlay .gsm-card-title{color:#fff;font-size:14px}
.gsm-card-overlay .gsm-card-price{color:#fff}
.gsm-card-foot-overlay{padding:10px 14px 14px;display:flex;justify-content:space-between;align-items:center;gap:8px}

/* Horizontal style */
.gsm-card--horizontal{flex-direction:row}
.gsm-card--horizontal .gsm-card-h-img{width:120px;flex-shrink:0;position:relative;overflow:hidden;background:#f8f9fa}
.gsm-card--horizontal .gsm-card-h-img img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:auto}
.gsm-card--horizontal .gsm-card-h-body{padding:14px;flex:1;display:flex;flex-direction:column;gap:4px}
@media(max-width:400px){.gsm-card--horizontal{flex-direction:column}.gsm-card--horizontal .gsm-card-h-img{width:100%}}

/* Empty state */
.gsm-empty-shop{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#aaa;gap:12px}
.gsm-empty-shop p{font-size:15px;color:#999;margin:0}

/* Pagination */
.gsm-pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:36px;flex-wrap:wrap}
.gsm-page-btn{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 12px;border-radius:8px;font-size:13px;font-weight:600;text-decoration:none;color:var(--gsm-s,#022A42);background:#f5f5f5;transition:all .15s;border:1px solid transparent;white-space:nowrap}
.gsm-page-btn:hover{background:var(--gsm-s,#022A42);color:#fff}
.gsm-page-btn.active{background:var(--gsm-s,#022A42);color:var(--gsm-p,#B8F612);border-color:var(--gsm-s,#022A42);cursor:default}
.gsm-page-btn.gsm-page-prev,.gsm-page-btn.gsm-page-next{padding:0 14px;font-weight:600}
.gsm-page-ellipsis{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:36px;font-size:14px;color:#aaa;user-select:none}
.gsm-page-prev,.gsm-page-next{font-size:18px;font-weight:400}
.gsm-page-info{font-size:12px;color:#aaa;margin-left:8px}

/* ═══════════════════════════════════════════════════
   SINGLE PRODUCT PAGE — inline styles moved here
═══════════════════════════════════════════════════ */
.gsm-sp{max-width:1100px;margin:0 auto;padding:28px 20px 60px;font-family:var(--gsm-font,Barlow,system-ui,sans-serif)}
.gsm-sp-bc{font-size:13px;color:#aaa;margin-bottom:22px}
.gsm-sp-bc a{color:#888;text-decoration:none}
.gsm-sp-bc a:hover{color:var(--gsm-s,#022A42)}
.gsm-sp-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-bottom:48px;align-items:start}
@media(max-width:760px){.gsm-sp-layout{grid-template-columns:1fr;gap:24px}}
.gsm-sp-main{width:100%;aspect-ratio:1;object-fit:cover;border-radius:14px;border:1px solid #eee;display:block;background:#f9f9f9}
.gsm-sp-main-wrap{position:relative;margin-bottom:10px}
.gsm-sp-badge{position:absolute;top:12px;left:12px;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:800;z-index:2}
.gsm-sp-badge--sale{background:#ef4444;color:#fff}
.gsm-sp-badge--new{background:var(--gsm-p,#B8F612);color:var(--gsm-s,#022A42)}
.gsm-sp-thumbs{display:flex;gap:8px;flex-wrap:wrap}
.gsm-sp-thumb{width:68px;height:68px;object-fit:cover;border-radius:8px;border:2px solid #eee;cursor:pointer;transition:border-color .15s;background:#f9f9f9}
.gsm-sp-thumb:hover,.gsm-sp-thumb.active{border-color:var(--gsm-p,#B8F612)}
.gsm-sp-cat{font-size:11px;text-transform:uppercase;letter-spacing:.07em;font-weight:800;display:block;margin-bottom:8px}
.gsm-sp-cat a{color:inherit;text-decoration:none}
.gsm-sp-title{font-size:2rem;font-weight:900;color:var(--gsm-s,#022A42);margin:0 0 10px;line-height:1.2}
.gsm-sp-sku{font-size:13px;color:#aaa;margin:0 0 14px}
.gsm-sp-price{display:flex;gap:10px;align-items:baseline;margin:0 0 14px;flex-wrap:wrap}
.gsm-sp-price-old{font-size:15px;color:#aaa;text-decoration:line-through}
.gsm-sp-price-big{font-size:2.1rem;font-weight:900;color:var(--gsm-s,#022A42)}
.gsm-sp-price-unit{font-size:13px;color:#aaa}
.gsm-sp-stock{font-size:13px;font-weight:600;margin:0 0 16px}
.gsm-sp-excerpt{color:#555;line-height:1.75;margin:0 0 20px;font-size:15px}
.gsm-sp-attrs{margin-bottom:20px}
.gsm-sp-attr-row{margin-bottom:14px}
.gsm-sp-attr-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#666;margin-bottom:7px}
.gsm-sp-attr-options{display:flex;gap:6px;flex-wrap:wrap}
.gsm-sp-attr-btn{padding:6px 14px;border:1.5px solid #ddd;border-radius:7px;font-size:13px;background:#fff;cursor:pointer;transition:all .15s;font-family:inherit;font-weight:500;color:#444}
.gsm-sp-attr-btn:hover{border-color:var(--gsm-s,#022A42);color:var(--gsm-s,#022A42)}
.gsm-sp-attr-btn.selected{background:var(--gsm-s,#022A42);color:var(--gsm-p,#B8F612);border-color:var(--gsm-s,#022A42)}
.gsm-sp-cta{display:flex;gap:10px;align-items:center;margin-bottom:12px;flex-wrap:wrap}
.gsm-sp-qty{display:flex;align-items:center;border:1.5px solid #e0e0e0;border-radius:8px;overflow:hidden}
.gsm-sp-qty-btn{width:36px;height:40px;border:none;background:#f7f7f7;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .12s;flex-shrink:0}
.gsm-sp-qty-btn:hover{background:#eee}
.gsm-sp-qty-val{width:44px;text-align:center;border:none;font-size:15px;font-weight:700;outline:none;color:var(--gsm-s,#022A42);background:#fff}
.gsm-sp-add-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 24px;border:none;border-radius:8px;font-size:15px;font-weight:800;cursor:pointer;transition:opacity .15s,transform .15s;font-family:inherit}
.gsm-sp-add-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}
.gsm-sp-add-btn:disabled{opacity:.45;cursor:not-allowed}
.gsm-sp-view-quote{font-size:13px;color:var(--gsm-s,#022A42);text-decoration:none;display:block;margin-bottom:18px;opacity:.7}
.gsm-sp-view-quote:hover{opacity:1;text-decoration:underline}
.gsm-sp-specs{border:1px solid #eee;border-radius:10px;overflow:hidden;margin-top:20px}
.gsm-sp-spec-row{display:flex;padding:10px 14px;border-bottom:1px solid #f5f5f5;font-size:13px;align-items:flex-start}
.gsm-sp-spec-row:last-child{border-bottom:none}
.gsm-sp-spec-row span{width:130px;color:#999;flex-shrink:0;font-size:12px;padding-top:1px}
.gsm-sp-spec-row strong{color:#333}
.gsm-sp-tabs{border-top:1px solid #eee;margin-top:8px}
.gsm-sp-tab-nav{display:flex;border-bottom:1px solid #eee;flex-wrap:wrap}
.gsm-sp-tab-btn{padding:12px 20px;border:none;background:none;font-size:14px;font-weight:600;color:#aaa;cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-1px;transition:all .15s;font-family:inherit}
.gsm-sp-tab-btn:hover{color:var(--gsm-s,#022A42)}
.gsm-sp-tab-btn.active{color:var(--gsm-s,#022A42);border-bottom-color:var(--gsm-p,#B8F612)}
.gsm-sp-tab-panel{display:none;padding:24px 0}
.gsm-sp-tab-panel.active{display:block}
.gsm-sp-desc p{margin-bottom:12px;line-height:1.8;color:#555}
.gsm-sp-attrs-table{width:100%;border-collapse:collapse;font-size:14px}
.gsm-sp-attrs-table tr{border-bottom:1px solid #eee}
.gsm-sp-attrs-table th{text-align:left;padding:10px 14px;background:#f9fafb;font-weight:600;color:#555;width:200px}
.gsm-sp-attrs-table td{padding:10px 14px;color:#333}
.gsm-attr-chip{display:inline-block;background:#f0f4f8;border-radius:4px;padding:2px 9px;font-size:13px;margin:2px 3px 2px 0}
.gsm-sp-related{margin-top:48px}
.gsm-sp-related h3{font-size:1.25rem;font-weight:800;color:var(--gsm-s,#022A42);margin:0 0 20px}

/* ═══════════════════════════════════════════════════
   REVIEWS
═══════════════════════════════════════════════════ */
.gsm-reviews{margin-top:40px;font-family:var(--gsm-font,system-ui,sans-serif)}
.gsm-reviews-title{font-size:1.3rem;font-weight:700;color:var(--gsm-secondary,#022A42);margin-bottom:20px}
.gsm-reviews-summary{display:flex;gap:28px;align-items:flex-start;margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid #eee;flex-wrap:wrap}
.gsm-reviews-avg{text-align:center;min-width:100px}
.gsm-avg-score{font-size:3rem;font-weight:900;color:var(--gsm-secondary,#022A42);line-height:1;margin-bottom:4px}
.gsm-avg-count{font-size:12px;color:#aaa;margin-top:4px}
.gsm-stars{color:#f59e0b;letter-spacing:-1px}
.gsm-star--empty{color:#ddd}
.gsm-reviews-dist{flex:1;min-width:200px}
.gsm-dist-row{display:flex;align-items:center;gap:10px;margin-bottom:6px;font-size:12px}
.gsm-dist-label{width:32px;color:#555;text-align:right;flex-shrink:0}
.gsm-dist-bar-wrap{flex:1;background:#f0f0f0;border-radius:4px;height:8px}
.gsm-dist-bar{background:#f59e0b;height:8px;border-radius:4px;transition:width .4s}
.gsm-dist-count{width:24px;color:#888;text-align:right}
.gsm-no-reviews{color:#aaa;font-size:14px;padding:20px 0}
.gsm-reviews-list{margin-bottom:32px}
.gsm-review-item{padding:20px 0;border-bottom:1px solid #eee}
.gsm-review-header{display:flex;gap:12px;margin-bottom:10px}
.gsm-avatar{border-radius:50%;width:40px;height:40px}
.gsm-reviewer-name{font-size:14px;font-weight:700;color:#333;display:block}
.gsm-verified-badge{font-size:11px;color:#10b981;font-weight:500}
.gsm-review-rating-date{display:flex;align-items:center;gap:8px;margin-top:2px}
.gsm-review-date{font-size:12px;color:#aaa}
.gsm-review-title{font-weight:700;font-size:14px;color:#222;margin-bottom:6px}
.gsm-review-body{font-size:14px;color:#555;line-height:1.7;margin-bottom:10px}
.gsm-review-actions{display:flex;align-items:center;gap:10px}
.gsm-helpful-text{font-size:12px;color:#aaa}
.gsm-helpful-btn{border:1px solid #ddd;background:#fff;border-radius:6px;padding:4px 10px;font-size:12px;cursor:pointer;display:flex;align-items:center;gap:5px;transition:background .15s}
.gsm-helpful-btn:hover{background:#f9fafb}
.gsm-review-form-wrap{background:#f9fafb;border:1px solid #eee;border-radius:12px;padding:24px;margin-top:8px}
.gsm-review-form-wrap h4{font-size:16px;font-weight:700;color:var(--gsm-secondary,#022A42);margin:0 0 20px}
.gsm-star-picker{display:flex;align-items:center;gap:6px}
.gsm-pick-star{background:none;border:none;font-size:28px;color:#ddd;cursor:pointer;padding:0;transition:color .1s;line-height:1}
.gsm-pick-star.active,.gsm-pick-star:hover,.gsm-pick-star.hover{color:#f59e0b}
.gsm-rating-label{font-size:13px;color:#888;margin-left:8px}
.gsm-form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:540px){.gsm-form-row-2{grid-template-columns:1fr}}
.gsm-field{margin-bottom:14px}
.gsm-field label{display:block;font-size:12px;font-weight:600;color:#555;margin-bottom:5px}
.gsm-field input,.gsm-field textarea,.gsm-field select{width:100%;padding:9px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;background:#fff;font-family:inherit;box-sizing:border-box}
.gsm-field textarea{height:100px;resize:vertical}
.gsm-btn.gsm-btn--primary{display:inline-flex;align-items:center;gap:7px;padding:11px 22px;background:var(--gsm-secondary,#022A42);color:var(--gsm-primary,#B8F612);border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit}
.gsm-form-notice{padding:10px 14px;border-radius:8px;font-size:13px;margin:8px 0}

/* Filters css */
.gsm-widget-price-filter,.gsm-shortcode-price-filter{padding:4px 0}
.gsm-price-slider-wrap{position:relative;height:30px;margin-bottom:10px}
.gsm-price-slider{-webkit-appearance:none;width:100%;height:4px;background:var(--gsm-s,#022A42);border-radius:2px;outline:none;position:absolute;top:50%;transform:translateY(-50%);pointer-events:all}
.gsm-price-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--gsm-p,#B8F612);border:2px solid var(--gsm-s,#022A42);cursor:pointer}
.gsm-price-range-display{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--gsm-s,#022A42);margin-bottom:12px}
.gsm-attr-filter-list{list-style:none;margin:0;padding:0}
.gsm-attr-filter-item{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:13px;cursor:pointer}
.gsm-attr-filter-item input{cursor:pointer;accent-color:var(--gsm-s,#022A42)}
.gsm-cat-widget-list{list-style:none;margin:0;padding:0}
.gsm-cat-widget-link{display:flex;justify-content:space-between;padding:6px 0;font-size:13px;color:var(--gsm-s,#022A42);text-decoration:none;border-bottom:1px solid #f5f5f5}
.gsm-cat-widget-link:hover{opacity:.7}
.gsm-cat-widget-link span{color:#aaa;font-size:12px}

/* Mini cart header widget */
.gsm-mini-cart-trigger{position:relative;cursor:pointer;display:inline-flex;align-items:center;gap:6px;color:inherit;padding:6px;border-radius:8px;transition:background .15s}
.gsm-mini-cart-trigger:hover{background:rgba(0,0,0,.06)}
.gsm-mini-cart-count{position:absolute;top:-6px;right:-6px;background:var(--gsm-primary,#B8F612);color:var(--gsm-secondary,#022A42);border-radius:50%;width:18px;height:18px;font-size:10px;font-weight:900;display:flex;align-items:center;justify-content:center;transition:transform .2s;line-height:1}
.gsm-mini-cart-count.has-items{transform:scale(1.1)}
.gsm-mini-cart-label{font-size:13px;font-weight:600}
.gsm-mini-cart-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:310px;background:#fff;border:0.5px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.12);z-index:99999;opacity:0;transform:translateY(-6px);transition:opacity .15s,transform .15s;pointer-events:none;font-family:var(--gsm-font,system-ui)}
.gsm-mini-cart-dropdown.is-open{opacity:1;transform:translateY(0);pointer-events:all}

/* ═══════════════════════════════════════════════════
   CHECKOUT POPUP — professional
═══════════════════════════════════════════════════ */
.gsm-checkout-page{font-family:var(--gsm-font,Barlow,system-ui,sans-serif);max-width:680px;margin:0 auto;padding:28px 16px 60px}
.gsm-checkout-empty{text-align:center;padding:56px 20px}
.gsm-checkout-empty__icon{width:76px;height:76px;border-radius:50%;background:var(--gsm-s,#022A42);color:var(--gsm-p,#B8F612);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.gsm-checkout-empty h2{font-size:1.4rem;font-weight:800;color:var(--gsm-s,#022A42);margin:0 0 8px}
.gsm-checkout-empty p{color:#888;margin:0 0 24px;font-size:15px}
.gsm-cta-btn{display:inline-flex!important;align-items:center!important;gap:8px!important;padding:12px 24px!important;background:var(--gsm-s,#022A42)!important;color:var(--gsm-p,#B8F612)!important;border:none!important;border-radius:10px!important;font-size:15px!important;font-weight:700!important;cursor:pointer!important;text-decoration:none!important;transition:opacity .15s,transform .15s!important;font-family:inherit!important;box-shadow:none!important;outline:none!important}
.gsm-cta-btn:hover{opacity:.9!important;transform:translateY(-1px)!important;color:var(--gsm-p,#B8F612)!important;text-decoration:none!important}
.gsm-checkout-summary-bar{background:var(--gsm-s,#022A42)!important;border-radius:12px!important;padding:16px 20px!important;margin-bottom:20px!important;border:none!important}
.gsm-csb-inner{display:flex!important;justify-content:space-between!important;align-items:center!important;gap:12px!important;flex-wrap:wrap!important}
.gsm-csb-count{font-size:2rem!important;font-weight:900!important;color:var(--gsm-p,#B8F612)!important;line-height:1!important}
.gsm-csb-label{font-size:13px!important;color:rgba(255,255,255,.65)!important;margin-left:6px!important}
.gsm-csb-left{display:flex;align-items:baseline}
.gsm-checkout-items-list{display:flex!important;flex-direction:column!important;gap:10px!important;margin-bottom:20px!important}
.gsm-cli-item{display:flex!important;align-items:center!important;gap:14px!important;padding:14px!important;background:#fff!important;border:1px solid #eee!important;border-radius:12px!important;box-shadow:0 1px 4px rgba(0,0,0,.04)!important}
.gsm-cli-img{width:52px!important;height:52px!important;border-radius:8px!important;overflow:hidden!important;flex-shrink:0!important;background:#f0f0f0!important}
.gsm-cli-img img,.gsm-cli-img-ph{width:100%!important;height:100%!important;object-fit:cover!important;display:block!important}
.gsm-cli-info{flex:1!important;min-width:0!important}
.gsm-cli-name{font-size:14px!important;font-weight:600!important;color:var(--gsm-s,#022A42)!important;text-decoration:none!important;display:block!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}
.gsm-cli-name:hover{text-decoration:underline!important}
.gsm-cli-sku{font-size:12px!important;color:#aaa!important}
.gsm-cli-qty{display:flex!important;align-items:center!important;gap:6px!important;flex-shrink:0!important}
.gsm-cli-qb{width:32px!important;height:32px!important;border:none!important;background:var(--gsm-s,#022A42)!important;color:var(--gsm-p,#B8F612)!important;border-radius:7px!important;cursor:pointer!important;font-size:16px!important;font-weight:700!important;display:flex!important;align-items:center!important;justify-content:center!important;transition:opacity .12s!important;box-shadow:none!important;outline:none!important}
.gsm-cli-qb:hover{opacity:.85!important}
.gsm-cli-qv{font-size:14px!important;font-weight:700!important;min-width:24px!important;text-align:center!important;color:var(--gsm-s,#022A42)!important}
.gsm-cli-rm{background:var(--gsm-s,#022A42)!important;border:none!important;cursor:pointer!important;color:var(--gsm-p,#B8F612)!important;padding:0!important;border-radius:7px!important;display:flex!important;align-items:center!important;justify-content:center!important;width:32px!important;height:32px!important;flex-shrink:0!important;box-shadow:none!important;outline:none!important}
.gsm-cli-rm:hover{opacity:.75!important}
/* Popup — todas as cores forçadas via !important para vencer temas externos */
.gsm-popup-overlay{position:fixed!important;inset:0!important;background:rgba(0,0,0,.55)!important;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:999990!important;display:flex!important;align-items:flex-end!important;justify-content:center!important;opacity:0!important;pointer-events:none!important;transition:opacity .22s ease}
@media(min-width:600px){.gsm-popup-overlay{align-items:center!important}}
.gsm-popup-overlay.is-open{opacity:1!important;pointer-events:all!important}
.gsm-popup{background:#fff!important;width:100%!important;max-width:500px!important;border-radius:20px 20px 0 0!important;max-height:94vh!important;overflow-y:auto!important;transform:translateY(32px);transition:transform .3s cubic-bezier(.34,1.2,.64,1);box-shadow:0 -8px 60px rgba(0,0,0,.2)!important;display:flex!important;flex-direction:column!important}
@media(min-width:600px){.gsm-popup{border-radius:20px!important;transform:scale(.95)}}
.gsm-popup-overlay.is-open .gsm-popup{transform:translateY(0)}
@media(min-width:600px){.gsm-popup-overlay.is-open .gsm-popup{transform:scale(1)}}
body.gsm-popup-open{overflow:hidden!important}
.gsm-popup-hdr{display:flex!important;align-items:flex-start!important;justify-content:space-between!important;padding:20px 20px 16px!important;border-bottom:1px solid #f0f0f0!important;flex-shrink:0!important;background:#fff!important}
.gsm-popup-sub{font-size:10px!important;font-weight:700!important;text-transform:uppercase!important;letter-spacing:.09em!important;color:var(--gsm-s,#022A42)!important;opacity:.5!important;margin:0 0 2px!important}
.gsm-popup-ttl{font-size:1.2rem!important;font-weight:800!important;color:var(--gsm-s,#022A42)!important;margin:0!important;line-height:1.2!important}
.gsm-popup-x{background:var(--gsm-s,#022A42)!important;border:none!important;cursor:pointer!important;color:var(--gsm-p,#B8F612)!important;padding:8px!important;border-radius:10px!important;display:flex!important;align-items:center!important;justify-content:center!important;transition:opacity .15s!important;width:36px!important;height:36px!important;flex-shrink:0!important}
.gsm-popup-x:hover{opacity:.85!important}
.gsm-popup-steps{display:flex!important;align-items:center!important;padding:12px 20px!important;background:#f8f9fa!important;border-bottom:1px solid #eee!important;flex-shrink:0!important}
.gsm-stp{display:flex!important;align-items:center!important;gap:6px!important;font-size:12px!important;color:#bbb!important;font-weight:500!important;white-space:nowrap!important}
.gsm-stp.active{color:var(--gsm-s,#022A42)!important}
.gsm-sn{width:22px!important;height:22px!important;border-radius:50%!important;border:2px solid #ddd!important;display:flex!important;align-items:center!important;justify-content:center!important;font-size:10px!important;font-weight:800!important;flex-shrink:0!important;transition:all .2s!important;background:#fff!important;color:#bbb!important}
.gsm-stp.active .gsm-sn{background:var(--gsm-s,#022A42)!important;color:var(--gsm-p,#B8F612)!important;border-color:var(--gsm-s,#022A42)!important}
.gsm-stp.done .gsm-sn{background:var(--gsm-p,#B8F612)!important;color:var(--gsm-s,#022A42)!important;border-color:var(--gsm-p,#B8F612)!important}
.gsm-sdiv{flex:1!important;height:1px!important;background:#e5e7eb!important;margin:0 8px!important}
.gsm-pbd{padding:16px 20px!important;background:#fff!important}
.gsm-pbd--ok{text-align:center!important;padding:40px 20px!important}
.gsm-pitems{display:flex!important;flex-direction:column!important;gap:8px!important;max-height:240px!important;overflow-y:auto!important;margin-bottom:4px!important}
.gsm-pi{display:flex!important;align-items:center!important;gap:10px!important;padding:10px!important;background:#f9fafb!important;border-radius:10px!important;border:1px solid #eee!important}
.gsm-pi-img{width:44px!important;height:44px!important;border-radius:8px!important;overflow:hidden!important;flex-shrink:0!important;background:#eee!important}
.gsm-pi-img img{width:100%!important;height:100%!important;object-fit:cover!important;display:block!important}
.gsm-pi-ph{width:44px!important;height:44px!important;background:#e5e7eb!important;border-radius:8px!important}
.gsm-pi-info{flex:1!important;min-width:0!important}
.gsm-pi-nm{font-size:13px!important;font-weight:600!important;color:var(--gsm-s,#022A42)!important;display:block!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}
.gsm-pi-sk{font-size:11px!important;color:#aaa!important}
.gsm-pi-qty{display:flex!important;align-items:center!important;gap:4px!important;flex-shrink:0!important}
.gsm-pqb{width:26px!important;height:26px!important;border:none!important;background:var(--gsm-s,#022A42)!important;color:var(--gsm-p,#B8F612)!important;border-radius:6px!important;cursor:pointer!important;font-size:16px!important;display:flex!important;align-items:center!important;justify-content:center!important;line-height:1!important;font-weight:700!important;flex-shrink:0!important}
.gsm-pqb:hover{opacity:.85!important}
.gsm-pqv{font-size:14px!important;font-weight:700!important;min-width:22px!important;text-align:center!important;color:var(--gsm-s,#022A42)!important}
.gsm-pi-rm{background:var(--gsm-s,#022A42)!important;border:none!important;cursor:pointer!important;color:var(--gsm-p,#B8F612)!important;padding:5px!important;border-radius:6px!important;display:flex!important;flex-shrink:0!important;width:26px!important;height:26px!important;align-items:center!important;justify-content:center!important}
.gsm-pi-rm:hover{opacity:.75!important}
.gsm-pfg{display:grid!important;grid-template-columns:1fr 1fr!important;gap:12px!important}
@media(max-width:460px){.gsm-pfg{grid-template-columns:1fr!important}}
.gsm-pf{display:flex!important;flex-direction:column!important;gap:4px!important}
.gsm-pf--full{grid-column:1/-1!important}
.gsm-pf label{font-size:12px!important;font-weight:600!important;color:#444!important}
.gsm-req{color:#ef4444!important}
.gsm-pf input,.gsm-pf select,.gsm-pf textarea{padding:9px 11px!important;border:1.5px solid #e5e7eb!important;border-radius:8px!important;font-size:14px!important;font-family:inherit!important;background:#fff!important;transition:border-color .15s!important;outline:none!important;color:#333!important;width:100%!important;box-sizing:border-box!important;-webkit-appearance:none!important;appearance:none!important}
.gsm-pf input:focus,.gsm-pf select:focus,.gsm-pf textarea:focus{border-color:var(--gsm-s,#022A42)!important;box-shadow:0 0 0 3px color-mix(in srgb,var(--gsm-s,#022A42) 10%,transparent)!important}
.gsm-pf textarea{resize:vertical!important;min-height:72px!important}
.gsm-sw{position:relative!important}
.gsm-sw select{appearance:none!important;-webkit-appearance:none!important;padding-right:32px!important;cursor:pointer!important}
.gsm-sarr{position:absolute!important;right:10px!important;top:50%!important;transform:translateY(-50%)!important;pointer-events:none!important;color:#999!important}
.gsm-pft{display:flex!important;align-items:center!important;justify-content:space-between!important;padding-top:14px!important;margin-top:10px!important;border-top:1px solid #f0f0f0!important;gap:10px!important;flex-wrap:wrap!important;background:#fff!important}
.gsm-plink{font-size:13px!important;color:var(--gsm-s,#022A42)!important;text-decoration:none!important;opacity:.6!important;display:flex!important;align-items:center!important;gap:4px!important}
.gsm-plink:hover{opacity:1!important;text-decoration:underline!important}
.gsm-pbck{background:#fff!important;border:1.5px solid var(--gsm-s,#022A42)!important;border-radius:8px!important;padding:9px 18px!important;font-size:13px!important;font-weight:700!important;cursor:pointer!important;color:var(--gsm-s,#022A42)!important;font-family:inherit!important;transition:all .15s!important}
.gsm-pbck:hover{background:var(--gsm-s,#022A42)!important;color:var(--gsm-p,#B8F612)!important}
.gsm-pnxt{background:var(--gsm-s,#022A42)!important;color:var(--gsm-p,#B8F612)!important;border:none!important;border-radius:8px!important;padding:10px 22px!important;font-size:14px!important;font-weight:700!important;cursor:pointer!important;font-family:inherit!important;transition:opacity .15s!important;margin-left:auto!important}
.gsm-pnxt:hover:not(:disabled){opacity:.88!important}
.gsm-pnxt:disabled{opacity:.35!important;cursor:not-allowed!important}
.gsm-psub{background:var(--gsm-s,#022A42)!important;color:var(--gsm-p,#B8F612)!important;border:none!important;border-radius:8px!important;padding:11px 24px!important;font-size:14px!important;font-weight:700!important;cursor:pointer!important;display:flex!important;align-items:center!important;gap:8px!important;font-family:inherit!important;transition:opacity .15s!important;min-width:148px!important;justify-content:center!important}
.gsm-psub:hover:not(:disabled){opacity:.88!important}
.gsm-psub:disabled{opacity:.45!important;cursor:not-allowed!important}
.gsm-pnotice{padding:10px 13px!important;border-radius:8px!important;font-size:13px!important;margin:8px 0 0!important}
.gsm-pnotice.error{background:#fef2f2!important;color:#991b1b!important;border:1px solid #fecaca!important}
.gsm-pnotice.success{background:#f0fdf4!important;color:#166534!important;border:1px solid #bbf7d0!important}
.gsm-spin{width:15px!important;height:15px!important;border:2px solid rgba(255,255,255,.25)!important;border-top-color:var(--gsm-p,#B8F612)!important;border-radius:50%!important;animation:gsm-spin .65s linear infinite!important;display:inline-block!important}
@keyframes gsm-spin{to{transform:rotate(360deg)}}
.gsm-ok-icon{width:76px!important;height:76px!important;border-radius:50%!important;background:color-mix(in srgb,var(--gsm-p,#B8F612) 20%,#fff)!important;color:var(--gsm-s,#022A42)!important;display:flex!important;align-items:center!important;justify-content:center!important;margin:0 auto 18px!important}
.gsm-ok-ttl{font-size:1.3rem!important;font-weight:800!important;color:var(--gsm-s,#022A42)!important;margin:0 0 8px!important}
.gsm-ok-msg{color:#555!important;font-size:14px!important;margin:0 0 10px!important}
.gsm-ok-ref{font-size:13px!important;color:#999!important;margin:0 0 24px!important}

/* ════════════════════════════════════════════════════
   FIX 1: PRODUCT CARD — button always aligned at bottom
   The footer is pushed to the bottom via flex + margin-top:auto
   on a spacer div, button always at same vertical position
════════════════════════════════════════════════════ */
.gsm-product-card {
  display: flex;
  flex-direction: column;
}
.gsm-card-body {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.gsm-card-body .gsm-card-spacer {
  flex: 1;
}
/* Footer always sticks to the bottom of the card */
.gsm-card-footer {
  margin-top: auto;
  padding: 10px 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  border-top: 1px solid #f5f5f5;
  flex-wrap: nowrap;
  min-width: 0;
}
/* Add button: adapts to available space in narrow columns */
.gsm-add-btn,
.gsm-add-btn:not(.gsm-added) {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
  padding: 8px 10px !important;
  background: var(--gsm-s, #022A42) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 8px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  font-family: inherit !important;
  white-space: nowrap !important;
  flex: 1 !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  outline: none !important;
  box-shadow: none !important;
  text-decoration: none !important;
  line-height: 1.4 !important;
  transition: background .18s, transform .12s !important;
}
.gsm-add-btn:hover:not(:disabled) {
  background: var(--gsm-p, #B8F612) !important;
  color: var(--gsm-s, #022A42) !important;
  transform: translateY(-1px) !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}
.gsm-add-btn.gsm-added {
  background: #10b981 !important;
  color: #fff !important;
  border: none !important;
  outline: none !important;
}
.gsm-add-btn:disabled {
  background: #d1d5db !important;
  color: #9ca3af !important;
  cursor: not-allowed !important;
  transform: none !important;
  border: none !important;
}
.gsm-add-btn:focus,
.gsm-add-btn:active {
  outline: none !important;
  border: none !important;
  box-shadow: none !important;
}

/* ════════════════════════════════════════════════════
   FIX 3: BUBBLE — no auto-show, starts hidden always
   Remove the is-visible auto-toggle; user places it in header
   Only the JS-driven count badge shows
════════════════════════════════════════════════════ */
/* When placed as static widget in header (not floating) */
.gsm-bubble-inline {
  display: inline-flex;
  align-items: center;
  position: static !important;
  bottom: auto !important;
  right: auto !important;
  transform: none !important;
  opacity: 1 !important;
  pointer-events: all !important;
}
.gsm-bubble-inline .gsm-bubble-btn {
  width: auto !important;
  height: auto !important;
  padding: 8px !important;
  border-radius: 8px !important;
  background: transparent !important;
  color: inherit !important;
  box-shadow: none !important;
}
/* Fixed floating bubble — only show when JS adds is-visible */
#gsm-bubble.gsm-bubble:not(.gsm-bubble-inline) {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  transform: scale(0.88);
  transition: opacity .2s, transform .22s;
}
#gsm-bubble.gsm-bubble.is-visible:not(.gsm-bubble-inline) {
  opacity: 1;
  pointer-events: all;
  transform: scale(1);
}

/* ════════════════════════════════════════════════════
   FIX 2: DRAWER — complete redesign, clean + modern
   All theme button overrides reset
════════════════════════════════════════════════════ */
/* Hard reset on ALL buttons inside drawer */
#gsm-drawer button,
#gsm-drawer button:focus,
#gsm-drawer button:hover,
#gsm-drawer button:active {
  outline: none !important;
  box-shadow: none !important;
}
/* OLD aside drawer — completely hidden, replaced by popup overlay */
#gsm-drawer {
  display: none !important;
}
#gsm-drawer.is-open { display: none !important; }
/* NEW popup overlay — centred, full screen */
#gsm-drawer-overlay {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0,0,0,.4) !important;
  backdrop-filter: blur(4px) !important;
  -webkit-backdrop-filter: blur(4px) !important;
  z-index: 999990 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity .22s ease !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px !important;
}
#gsm-drawer-overlay.is-open {
  opacity: 1 !important;
  pointer-events: all !important;
}

/* Drawer header — slim, clean */
.gsm-drawer-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  height: 56px;
  border-bottom: 1px solid #f0f0f0;
  flex-shrink: 0;
  background: #fff;
}
.gsm-drawer-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 700;
  color: #111;
  letter-spacing: -.01em;
}
.gsm-drawer-count-pill {
  background: var(--gsm-s, #022A42);
  color: #fff;
  border-radius: 20px;
  padding: 2px 9px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.6;
}
.gsm-drawer-close {
  width: 32px !important;
  height: 32px !important;
  background: #f5f5f5 !important;
  border: none !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  color: #888 !important;
  font-size: 18px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background .15s, color .15s !important;
  padding: 0 !important;
  outline: none !important;
  box-shadow: none !important;
}
.gsm-drawer-close:hover {
  background: #111 !important;
  color: #fff !important;
}

/* Drawer item — redesigned clean row */
.gsm-drawer-items { display: flex; flex-direction: column; }
.gsm-drawer-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  border-bottom: 1px solid #f5f5f5;
  transition: background .1s;
}
.gsm-drawer-item:hover { background: #fafafa; }
.gsm-drawer-item-img {
  width: 52px;
  height: 52px;
  border-radius: 8px;
  object-fit: cover;
  flex-shrink: 0;
  background: #f5f5f5;
}
.gsm-drawer-item-img--ph {
  width: 52px;
  height: 52px;
  border-radius: 8px;
  background: #f0f0f0;
  flex-shrink: 0;
}
.gsm-drawer-item-info { flex: 1; min-width: 0; }
.gsm-drawer-item-name {
  font-size: 13px;
  font-weight: 600;
  color: #111;
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin: 0 0 6px;
}
.gsm-drawer-item-sku { font-size: 11px; color: #aaa; margin: 0 0 6px; }

/* Qty controls — clean pill shape */
.gsm-drawer-qty {
  display: inline-flex;
  align-items: center;
  background: #f5f5f5;
  border-radius: 20px;
  overflow: hidden;
  gap: 0;
}
.gsm-drawer-qty-btn {
  width: 28px !important;
  height: 28px !important;
  background: transparent !important;
  border: none !important;
  cursor: pointer !important;
  font-size: 16px !important;
  font-weight: 300 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #333 !important;
  transition: background .12s !important;
  border-radius: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  flex-shrink: 0 !important;
}
.gsm-drawer-qty-btn:hover {
  background: #e5e5e5 !important;
}
.gsm-drawer-qty-val {
  font-size: 13px;
  font-weight: 700;
  min-width: 24px;
  text-align: center;
  color: #111;
  line-height: 28px;
}

/* Remove button */
.gsm-drawer-remove {
  background: transparent !important;
  border: none !important;
  cursor: pointer !important;
  color: #d1d5db !important;
  padding: 4px !important;
  border-radius: 6px !important;
  display: flex !important;
  align-items: center !important;
  flex-shrink: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  transition: color .15s, background .15s !important;
}
.gsm-drawer-remove:hover {
  color: #ef4444 !important;
  background: #fff !important;
}

/* Drawer empty */
.gsm-drawer-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 20px;
  text-align: center;
  color: #ddd;
  gap: 12px;
  flex: 1;
}
.gsm-drawer-empty p { font-size: 14px; color: #bbb; margin: 0; }
.gsm-drawer-empty small { font-size: 12px; color: #ddd; }

/* Drawer footer */
.gsm-drawer-foot {
  padding: 16px 20px;
  border-top: 1px solid #f0f0f0;
  flex-shrink: 0;
  background: #fff;
}
.gsm-drawer-summary {
  font-size: 11px;
  color: #aaa;
  margin: 0 0 10px;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.gsm-drawer-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 13px 20px;
  background: var(--gsm-s, #022A42);
  color: #fff;
  border-radius: 10px;
  text-decoration: none;
  font-size: 14px;
  font-weight: 700;
  transition: background .15s;
  letter-spacing: -.01em;
  border: none;
}
.gsm-drawer-cta:hover { background: #033459; }
.gsm-drawer-cta span { color: var(--gsm-p, #B8F612); }

/* ═══════════════════════════════════════════════
   MOBILE & TABLET OPTIMISATIONS — v1.6.0
   All rules below are additive / override specific
═══════════════════════════════════════════════ */

/* ── Filter bar: mobile-first collapsible layout ── */
@media(max-width:768px){
  .gsm-filter-bar{flex-direction:column;gap:10px;padding:12px}
  .gsm-search-wrap{width:100%!important;min-width:0!important}
  .gsm-select-wrap{width:100%}
  .gsm-filter-select{width:100%!important;min-width:0!important;font-size:16px!important} /* 16px prevents iOS zoom */
  .gsm-filter-reset{width:100%;justify-content:center}
}

/* ── Mini cart dropdown: white bg, gray text ── */
.gsm-mini-cart-header{
  background:#fff!important;
  border-bottom:1px solid #f0f0f0!important;
  padding:16px 18px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
}
.gsm-mini-cart-title{
  font-size:14px!important;
  font-weight:700!important;
  color:#333!important;
  display:flex!important;
  align-items:center!important;
  gap:8px!important;
}
.gsm-mini-count-pill{
  background:var(--gsm-s,#022A42)!important;
  color:var(--gsm-p,#B8F612)!important;
  border-radius:20px!important;
  padding:2px 9px!important;
  font-size:11px!important;
  font-weight:800!important;
}
.gsm-mini-cart-close{
  background:none!important;
  border:none!important;
  color:#aaa!important;
  font-size:22px!important;
  cursor:pointer!important;
  line-height:1!important;
  padding:4px!important;
  transition:color .15s!important;
}
.gsm-mini-cart-close:hover{color:#333!important}
.gsm-mini-cart-body{background:#fff!important}
.gsm-mini-item{display:flex!important;align-items:center!important;gap:10px!important;padding:10px 18px!important;border-bottom:1px solid #f7f7f7!important;background:#fff!important}
.gsm-mini-item-name{font-size:13px!important;font-weight:600!important;color:#333!important;text-decoration:none!important;display:block!important;line-height:1.4!important}
.gsm-mini-item-name:hover{color:var(--gsm-s,#022A42)!important}
.gsm-mini-item-sku{font-size:11px!important;color:#aaa!important;display:block!important;margin-top:2px!important}
.gsm-mini-item-img{width:48px!important;height:48px!important;border-radius:8px!important;overflow:hidden!important;flex-shrink:0!important;background:#f5f5f5!important}
.gsm-mini-item-img img{width:100%!important;height:100%!important;object-fit:cover!important}
.gsm-mini-item-qty{display:flex!important;align-items:center!important;gap:6px!important;margin-top:6px!important}
.gsm-mini-qty-btn{width:24px!important;height:24px!important;border-radius:6px!important;border:none!important;background:var(--gsm-s,#022A42)!important;color:var(--gsm-p,#B8F612)!important;font-size:14px!important;cursor:pointer!important;display:flex!important;align-items:center!important;justify-content:center!important;font-weight:700!important;line-height:1!important}
.gsm-mini-qty-val{font-size:13px!important;font-weight:700!important;min-width:20px!important;text-align:center!important;color:#333!important}
.gsm-mini-item-remove{background:none!important;border:none!important;cursor:pointer!important;color:#ddd!important;padding:4px!important;display:flex!important;align-items:center!important;margin-left:auto!important}
.gsm-mini-item-remove:hover{color:#ef4444!important}
.gsm-mini-cart-footer{padding:14px 18px!important;border-top:1px solid #f0f0f0!important;background:#fff!important}
.gsm-mini-subtotal{font-size:13px!important;color:#888!important;margin:0 0 10px!important}
.gsm-mini-checkout-btn{display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;padding:12px!important;background:var(--gsm-s,#022A42)!important;color:var(--gsm-p,#B8F612)!important;border-radius:10px!important;font-size:14px!important;font-weight:700!important;text-decoration:none!important;transition:opacity .15s!important}
.gsm-mini-checkout-btn:hover{opacity:.88!important}
.gsm-mini-cart-empty p{color:#aaa!important;font-size:13px!important}

/* Mini cart full-width on mobile */
@media(max-width:480px){
  .gsm-mini-cart-dropdown{
    position:fixed!important;
    top:auto!important;
    bottom:0!important;
    left:0!important;
    right:0!important;
    width:100%!important;
    border-radius:16px 16px 0 0!important;
    max-height:75vh!important;
    overflow-y:auto!important;
  }
}

/* ── Product page: NO sticky on mobile ── */
@media(max-width:680px){
  .gsm-sp-photo{position:relative!important;top:auto!important}
  .gsm-sp-grid{grid-template-columns:1fr!important;gap:12px!important}
  .gsm-sp-thumbs{flex-direction:row!important;gap:8px!important;padding:0 0 8px!important;overflow-x:auto!important;flex-wrap:nowrap!important;order:2!important;scrollbar-width:none}
  .gsm-sp-thumbs::-webkit-scrollbar{display:none}
  .gsm-sp-thumb{width:60px!important;height:60px!important;flex-shrink:0!important}
  .gsm-sp-photo{order:1!important}
  .gsm-sp-info{order:3!important}
  /* Title sizing on mobile */
  .gsm-sp-h1{font-size:1.3rem!important}
  .gsm-sp-trust{grid-template-columns:1fr!important;gap:12px!important}
  .gsm-sp-cta{flex-wrap:wrap!important}
  .gsm-sp-add-btn{min-width:0!important;width:100%!important;flex:none!important}
  .gsm-sp-qty{width:auto!important}
}
@media(max-width:960px)and(min-width:681px){
  .gsm-sp-photo{position:relative!important;top:auto!important}
  .gsm-sp-h1{font-size:1.45rem!important}
}

/* ── Product page: company colors for all text ── */
.gsm-sp-h1{color:var(--gs,#022A42)!important}
.gsm-sp-excerpt{color:#555!important;font-size:14px!important}
.gsm-sp-attr-lbl{color:#555!important}
.gsm-sp-attr-sel{color:var(--gs,#022A42)!important;background:color-mix(in srgb,var(--gp,#B8F612) 20%,#fff)!important}
.gsm-sp-cat-tag{color:var(--gs,#022A42)!important;opacity:.5!important}
.gsm-sp-meta-item{color:#888!important}
.gsm-sp-meta-item strong,.gsm-sp-meta-item a{color:var(--gs,#022A42)!important}
.gsm-sp-trust-ttl{color:var(--gs,#022A42)!important}
.gsm-sp-trust-txt{color:#777!important;font-size:12px!important}
.gsm-sp-trust-icon{color:var(--gs,#022A42)!important;opacity:.3!important}
.gsm-sp-tab-btn{color:#aaa!important}
.gsm-sp-tab-btn.active{color:var(--gs,#022A42)!important;border-bottom-color:var(--gp,#B8F612)!important}
.gsm-sp-desc{color:#444!important}
.gsm-sp-specs-table th{color:var(--gs,#022A42)!important;background:#f9fafb!important}
.gsm-sp-specs-table td{color:#444!important}
.gsm-sp-chip{color:var(--gs,#022A42)!important}
.gsm-sp-related-h{color:var(--gs,#022A42)!important}
/* Stock badge: bg white/light, text in status color */
.gsm-sp-stock{font-size:12px!important;padding:4px 12px!important}
/* Price notice: subtle, company accent */
.gsm-sp-price-notice{font-size:13px!important;color:#666!important;border-left-color:var(--gp,#B8F612)!important;background:#fafafa!important}
/* Breadcrumb: lighter */
.gsm-sp-bc{color:#bbb!important;font-size:12px!important}
.gsm-sp-bc a{color:#aaa!important}
.gsm-sp-bc-sep{color:#ddd!important}
/* Accent line: always primary color */
.gsm-sp-accent-line{background:var(--gp,#B8F612)!important}
/* Download button */
.gsm-sp-dl{border-color:var(--gs,#022A42)!important;color:var(--gs,#022A42)!important}
.gsm-sp-dl:hover{background:var(--gs,#022A42)!important;color:var(--gp,#B8F612)!important}

/* ── Global typography scale on mobile ── */
@media(max-width:480px){
  .gsm-card-title a{font-size:13px!important}
  .gsm-card-sku{font-size:11px!important}
  .gsm-card-excerpt{font-size:11px!important;-webkit-line-clamp:2!important}
  .gsm-add-btn{font-size:11px!important}
  .gsm-stock-dot{font-size:11px!important}
  .gsm-price{font-size:13px!important}
  .gsm-price-consult{font-size:12px!important}
  .gsm-filter-bar{gap:8px!important;padding:10px!important}
  .gsm-results-bar{font-size:12px!important}
  .gsm-pagination{gap:4px!important;margin-top:24px!important}
  .gsm-page-btn{min-width:32px!important;height:32px!important;font-size:12px!important;padding:0 8px!important}
  .gsm-page-btn.gsm-page-prev,.gsm-page-btn.gsm-page-next{padding:0 10px!important;font-size:12px!important}
  /* Popup mobile typography */
  .gsm-popup-ttl{font-size:1rem!important}
  .gsm-pf label{font-size:11px!important}
  .gsm-pf input,.gsm-pf select,.gsm-pf textarea{font-size:16px!important} /* prevent iOS zoom */
  .gsm-pfg{gap:10px!important}
  .gsm-pi-nm{font-size:12px!important}
  .gsm-pi-sk{font-size:10px!important}
}

/* ── Drawer: full overlay on small screens ── */
@media(max-width:480px){
  .gsm-drawer{width:100vw!important;box-shadow:none!important}
  .gsm-drawer-head{padding:14px 16px!important}
  .gsm-drawer-item{padding:10px 16px!important}
}

/* ── Shop grid: always 1 column on mobile & tablet ── */
@media(max-width:960px){
  .gsm-grid{grid-template-columns:1fr!important;gap:14px!important}
}

/* ── Filter bar: tablet layout ── */
@media(max-width:768px)and(min-width:541px){
  .gsm-filter-bar{flex-wrap:wrap!important}
  .gsm-search-wrap{flex:1 1 100%!important}
  .gsm-select-wrap{flex:1!important}
}

/* ── Category pills scrollable row on mobile ── */
@media(max-width:768px){
  .gsm-active-tag{font-size:11px!important}
  .gsm-results-count{font-size:12px!important}
}

/* ── Checkout page mobile ── */
@media(max-width:480px){
  .gsm-checkout-page{padding:16px 12px 48px!important}
  .gsm-checkout-summary-bar{border-radius:10px!important;padding:12px 14px!important}
  .gsm-csb-count{font-size:1.6rem!important}
  .gsm-csb-label{font-size:12px!important}
  .gsm-cli-item{padding:10px 12px!important;gap:10px!important}
  .gsm-cli-img{width:44px!important;height:44px!important}
  .gsm-cli-name{font-size:13px!important}
}

/* ═══════════════════════════════════════════════
   CUSTOM DROPDOWN — gsm-cdd
   Branco, minimalista, scroll interno, sem popup nativo
═══════════════════════════════════════════════ */
.gsm-cdd-wrap{position:relative;flex-shrink:0}
.gsm-cdd-btn{display:inline-flex!important;align-items:center!important;gap:6px!important;padding:9px 13px!important;background:#fff!important;border:1.5px solid #d9d9d9!important;border-radius:8px!important;font-size:13px!important;font-weight:500!important;color:#555!important;cursor:pointer!important;font-family:inherit!important;white-space:nowrap!important;transition:border-color .15s,color .15s!important;max-width:170px!important;box-shadow:none!important;text-transform:none!important;letter-spacing:0!important}
.gsm-cdd-btn:hover{border-color:#aaa!important;color:#333!important;background:#fff!important}
.gsm-cdd-wrap.gsm-cdd-open .gsm-cdd-btn{border-color:#999!important;color:#333!important;background:#fff!important}
.gsm-cdd-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:130px;color:inherit!important}
.gsm-cdd-arr{flex-shrink:0;color:#aaa!important;transition:transform .2s;width:11px!important;height:11px!important}
.gsm-cdd-wrap.gsm-cdd-open .gsm-cdd-arr{transform:rotate(180deg)}

/* Panel — white, compact, max-height with scroll */
.gsm-cdd-panel{
  display:none;
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  min-width:220px;
  max-width:min(320px,90vw);
  max-height:300px;
  overflow-y:auto;
  background:#fff;
  border:1px solid #e0e0e0;
  border-radius:12px;
  box-shadow:0 8px 28px rgba(0,0,0,.1);
  z-index:99999;
  padding:0;
  scrollbar-width:thin;
  scrollbar-color:#e0e0e0 transparent;
  -webkit-overflow-scrolling:touch;
}
.gsm-cdd-panel::-webkit-scrollbar{width:4px}
.gsm-cdd-panel::-webkit-scrollbar-track{background:transparent}
.gsm-cdd-panel::-webkit-scrollbar-thumb{background:#e0e0e0;border-radius:4px}
.gsm-cdd-wrap.gsm-cdd-open .gsm-cdd-panel{display:flex;flex-direction:column}

/* Header inside panel with title + close button */
.gsm-cdd-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 16px 10px;
  border-bottom:1px solid #f0f0f0;
  flex-shrink:0;
  position:sticky;
  top:0;
  background:#fff;
  z-index:2;
}
.gsm-cdd-title{font-size:12px;font-weight:700;color:#aaa;text-transform:uppercase;letter-spacing:.06em}
.gsm-cdd-close{background:none;border:none;cursor:pointer;color:#bbb;font-size:20px;line-height:1;padding:2px 4px;border-radius:4px;transition:color .15s;display:flex;align-items:center;justify-content:center}
.gsm-cdd-close:hover{color:#555}

/* Scrollable list inside panel */
.gsm-cdd-list{overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}

/* Items */
.gsm-cdd-item{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  padding:11px 16px!important;
  font-size:13px!important;
  color:#555!important;
  text-decoration:none!important;
  transition:background .12s!important;
  gap:8px!important;
  border-bottom:1px solid #f5f5f5!important;
  line-height:1.4!important;
}
.gsm-cdd-item:last-child{border-bottom:none!important}
.gsm-cdd-item:hover{background:#f8f8f8!important;color:#333!important}
.gsm-cdd-item.active{color:var(--gsm-s,#022A42)!important;font-weight:600!important;background:#fafafa!important}
.gsm-cdd-item.active svg{color:var(--gsm-s,#022A42)!important;flex-shrink:0!important}
.gsm-cdd-item svg{flex-shrink:0!important;opacity:.7!important}
.gsm-cdd-count{color:#bbb!important;font-size:12px!important;font-weight:400!important;margin-left:2px!important}

/* Mobile: bottom sheet */
@media(max-width:480px){
  .gsm-cdd-panel{
    position:fixed!important;
    left:0!important;
    right:0!important;
    transform:none!important;
    top:auto!important;
    bottom:0!important;
    width:100vw!important;
    max-width:100vw!important;
    max-height:65vh!important;
    border-radius:18px 18px 0 0!important;
    box-shadow:0 -4px 32px rgba(0,0,0,.14)!important;
    padding:0!important;
    border:none!important;
    border-top:1px solid #eee!important;
  }
  .gsm-cdd-header{padding:14px 20px 12px!important}
  .gsm-cdd-title{font-size:13px!important}
  .gsm-cdd-btn{font-size:14px!important;padding:10px 13px!important}
  .gsm-cdd-item{padding:14px 20px!important;font-size:14px!important}
  .gsm-cdd-label{max-width:120px!important}
}

/* Tablet */
@media(max-width:768px)and(min-width:481px){
  .gsm-cdd-panel{max-width:min(300px,88vw);max-height:360px}
}
