/** Shopify CDN: Minification failed

Line 76:0 All "@import" rules must come first

**/
/* ==========================================================================
   GEEKZ STORE — Global Retro/Geeky Effects (Dark Edition)
   Retro glows, glitch text, scroll reveals, button effects, card glow,
   CRT scanlines, retro flicker, accent lines, cursor blink
   ========================================================================== */

/* --------------------------------------------------------------------------
   LAYOUT. Breathing Room — Increase page margins for a centered feel
   Overrides base.css --page-margin without touching the original file.
   Hero slideshow + marquee stay full-width (grid-column: 1 / -1).
   -------------------------------------------------------------------------- */

.page-width-wide,
.page-width-normal,
.page-width-narrow,
.page-width-content {
    --page-margin: 20px;
}

@media screen and (min-width: 750px) {
    .page-width-wide,
    .page-width-normal,
    .page-width-narrow,
    .page-width-content {
        --page-margin: 80px;
    }
}

@media screen and (min-width: 990px) {
    .page-width-wide,
    .page-width-normal,
    .page-width-narrow,
    .page-width-content {
        --page-margin: 120px;
    }
}

@media screen and (min-width: 1200px) {
    .page-width-wide,
    .page-width-normal,
    .page-width-narrow,
    .page-width-content {
        --page-margin: 160px;
    }
}

@media screen and (min-width: 1600px) {
    .page-width-wide,
    .page-width-normal,
    .page-width-narrow,
    .page-width-content {
        --page-margin: 200px;
    }
}

/* --------------------------------------------------------------------------
   LAYOUT. Center section headers (titles + subtitles)
   Overrides the inline --horizontal-alignment on header containers so that
   titles, descriptions and CTAs sit centered instead of left-aligned.
   -------------------------------------------------------------------------- */

.section-resource-list__header .group-block-content,
.section-resource-list__content > .group-block > .group-block-content {
    --horizontal-alignment: center !important;
}

/* --------------------------------------------------------------------------
   Orbitron — Retro-Futuristic Display Font (Headings + Logo Text)
   -------------------------------------------------------------------------- */

@import url("https://fonts.googleapis.com/css2?family=Orbitron:wght@400;500;700;900&family=Press+Start+2P&family=Russo+One&display=swap");

/* --------------------------------------------------------------------------
   W. Force announcement bar flush to top of viewport
   -------------------------------------------------------------------------- */

/* Nuke every possible gap above the header group */
body {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

#header-group {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

/* Pull the announcement section up and paint over any residual Shopify gap */
#header-group > .shopify-section:first-child {
    background: #ca400f;
    margin-top: -32px !important;
    position: relative;
    z-index: 1;
}

/* Kill ALL spacing the theme adds to .announcement-bar — override the grid, padding, everything */
.announcement-bar {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 6px 0 !important;
    margin: 0 !important;
    min-height: 0 !important;
    width: 100% !important;
}

/* Override .spacing-style variables so they can't re-add padding */
.announcement-bar.spacing-style {
    --section-top-offset: 0px;
    --padding-block-start: 0px !important;
    --padding-block-end: 0px !important;
    --padding-block: 0px !important;
    --padding-inline-start: 0px !important;
    --padding-inline-end: 0px !important;
    padding: 6px 0 !important;
    margin: 0 !important;
}

/* Slider takes full width, text perfectly centered */
.announcement-bar__slider {
    width: 100% !important;
    position: relative !important;
    justify-content: center !important;
    padding: 0 !important;
}

.announcement-bar__slides {
    width: 100% !important;
    max-width: 100% !important;
    text-align: center !important;
    margin: 0 auto !important;
    padding-inline: 32px !important;
}

/* Arrows float on the edges, don't push content */
.announcement-bar__slider > slideshow-arrows {
    position: absolute !important;
    inset: 0 !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    pointer-events: none;
    z-index: 2;
    padding: 0 8px !important;
}

.announcement-bar__slider > slideshow-arrows > * {
    pointer-events: auto;
}

/* Shrink the slideshow arrow buttons */
.announcement-bar__slider .slideshow-control {
    --button-size: 24px;
    width: 24px !important;
    height: 24px !important;
}

.announcement-bar__slider .slideshow-control .svg-wrapper {
    width: 12px;
    height: 12px;
}

/* --------------------------------------------------------------------------
   Z. Geekz Logo Text Styling
   -------------------------------------------------------------------------- */

.geekz-logo-text {
    font-family: "Orbitron", sans-serif;
    font-weight: 900;
    font-size: 1.8rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #ffffff;
    text-decoration: none;
    line-height: 1;
    white-space: nowrap;
    text-shadow:
        1px 1px 0 rgb(202 64 15 / 0.3),
        -1px -1px 0 rgb(0 102 255 / 0.2);
}

/* --------------------------------------------------------------------------
   X. Global Input Autofill Override
   Prevents Chrome/browser autofill from turning inputs light blue
   -------------------------------------------------------------------------- */

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active,
textarea:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px var(--color-input-background) inset !important;
    -webkit-text-fill-color: var(--color-input-text) !important;
    transition: background-color 5000s ease-in-out 0s;
}

/* --------------------------------------------------------------------------
   Y. Geekz Search Bar Styling
   -------------------------------------------------------------------------- */

/* Force the header center column to expand for a wider search bar */
@media screen and (min-width: 750px) {
    .header__row--top .header__columns {
        --header-center: 2fr !important;
        --header-left: 1fr !important;
        --header-right: 1fr !important;
    }
}

@media screen and (min-width: 750px) and (max-width: 1399px) {
    .header__row--top .header__columns {
        --header-center: 2fr !important;
        --header-left: auto !important;
        --header-right: auto !important;
    }
}

.geekz-search-bar {
    flex: 1;
    width: 100%;
    max-width: 680px;
    min-width: 180px;
    margin: 0 auto;
    position: relative;
}

@media screen and (min-width: 750px) and (max-width: 1399px) {
    .geekz-search-bar {
        max-width: 500px;
        min-width: 200px;
    }
}

.geekz-search-bar__form {
    display: flex;
    align-items: stretch;
    width: 100%;
    background: #1a1a1a;
    border: 2px solid #ca400f;
    border-radius: 6px;
    overflow: hidden;
    transition:
        border-color 0.2s ease,
        box-shadow 0.2s ease;
}

.geekz-search-bar__form:focus-within {
    border-color: #d4550f;
    box-shadow: 0 0 0 3px rgb(202 64 15 / 0.25);
}

.geekz-search-bar__input {
    flex: 1;
    border: none !important;
    background: #1a1a1a !important;
    padding: 8px 14px;
    font-size: 0.9375rem;
    color: #d0d0d0;
    outline: none !important;
    font-family: var(--font-body--family, sans-serif);
    -webkit-appearance: none;
    appearance: none;
    box-shadow: none !important;
    margin: 0;
    line-height: 1.4;
    border-radius: 0 !important;
}

.geekz-search-bar__input::placeholder {
    color: #777;
}

.geekz-search-bar__input:hover,
.geekz-search-bar__input:focus {
    background: #1a1a1a !important;
    box-shadow: none !important;
    border: none !important;
}

.geekz-search-bar__button {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px 18px;
    background: #ca400f;
    border: none;
    cursor: pointer;
    color: #ffffff;
    transition: background 0.2s ease;
    flex-shrink: 0;
}

.geekz-search-bar__button:hover {
    background: #a83a0c;
}

.geekz-search-bar__button svg {
    width: 18px;
    height: 18px;
}

@media screen and (max-width: 749px) {
    .geekz-search-bar {
        max-width: 100%;
        min-width: 0;
        padding: 0 8px;
    }
}

/* --------------------------------------------------------------------------
   0. Reduced-Motion Gate
   ALL animated effects are wrapped in this media query
   -------------------------------------------------------------------------- */

/* --------------------------------------------------------------------------
   TYPO. Global Typography — Orbitron Headings + Russo One Subheadings
   Applied outside reduced-motion gate (always visible)
   -------------------------------------------------------------------------- */

h1,
h2,
h3,
.h1,
.h2,
.h3 {
    font-family: "Orbitron", sans-serif !important;
}

h4,
h5,
h6,
.h4,
.h5,
.h6 {
    font-family: "Russo One", sans-serif !important;
}

@media (prefers-reduced-motion: no-preference) {
    /* --------------------------------------------------------------------------
     A. Heading Retro Glow
     Softer glow adapted for light backgrounds. Uses heading color for cohesion.
     -------------------------------------------------------------------------- */

    .section :is(h1, h2, h3, .h1, .h2, .h3),
    #footer-group .section :is(h2, h3, h4, .h2, .h3, .h4) {
        text-shadow:
            0 0 8px rgb(var(--color-foreground-heading-rgb) / 0.2),
            0 0 20px rgb(var(--color-foreground-heading-rgb) / 0.06);
    }

    /* --------------------------------------------------------------------------
     B. Hero Glitch Entrance
     One-shot glitch on slideshow heading — Blue + OrangyRed offset layers
     -------------------------------------------------------------------------- */

    .slideshow-section .slide__content h2 {
        position: relative;
        animation: geekz-glitch-entrance 0.9s ease-out both;
    }

    .slideshow-section .slide__content h2::before,
    .slideshow-section .slide__content h2::after {
        content: attr(data-text);
        position: absolute;
        inset: 0;
        overflow: hidden;
        pointer-events: none;
        opacity: 0;
    }

    .slideshow-section .slide__content h2::before {
        color: #0066ff;
        animation: geekz-glitch-layer-1 0.9s ease-out both;
    }

    .slideshow-section .slide__content h2::after {
        color: #ca400f;
        animation: geekz-glitch-layer-2 0.9s ease-out both;
    }

    @keyframes geekz-glitch-entrance {
        0% {
            opacity: 0;
            transform: translateX(-4px);
            filter: brightness(2) saturate(1.5);
        }
        10% {
            opacity: 1;
            transform: translateX(3px);
        }
        20% {
            transform: translateX(-2px);
            clip-path: inset(20% 0 40% 0);
        }
        30% {
            transform: translateX(0);
            clip-path: inset(60% 0 10% 0);
        }
        40% {
            clip-path: inset(0);
            filter: brightness(1.3);
        }
        100% {
            opacity: 1;
            transform: translateX(0);
            filter: brightness(1) saturate(1);
        }
    }

    @keyframes geekz-glitch-layer-1 {
        0% {
            opacity: 0;
        }
        10% {
            opacity: 0.7;
            transform: translateX(-3px);
            clip-path: inset(30% 0 30% 0);
        }
        20% {
            opacity: 0.5;
            transform: translateX(2px);
            clip-path: inset(50% 0 20% 0);
        }
        35% {
            opacity: 0;
        }
        100% {
            opacity: 0;
        }
    }

    @keyframes geekz-glitch-layer-2 {
        0% {
            opacity: 0;
        }
        15% {
            opacity: 0.6;
            transform: translateX(3px);
            clip-path: inset(10% 0 60% 0);
        }
        25% {
            opacity: 0.4;
            transform: translateX(-2px);
            clip-path: inset(40% 0 30% 0);
        }
        40% {
            opacity: 0;
        }
        100% {
            opacity: 0;
        }
    }

    /* --------------------------------------------------------------------------
     C. Button Glow + Shine Sweep on Hover
     Reduced intensity for light backgrounds
     -------------------------------------------------------------------------- */

    .button,
    .button-secondary {
        position: relative;
        overflow: hidden;
    }

    .button:hover {
        box-shadow:
            inset 0 0 0 var(--button-border-width, 0px)
                var(--button-border-color),
            0 0 8px rgb(var(--color-primary-rgb) / 0.3),
            0 0 18px rgb(var(--color-primary-rgb) / 0.1);
        transform: scale(1.03);
    }

    .button-secondary:hover {
        box-shadow:
            inset 0 0 0 var(--button-border-width, 1px)
                var(--button-border-color),
            0 0 8px rgb(var(--color-primary-rgb) / 0.25),
            0 0 15px rgb(var(--color-primary-rgb) / 0.08);
        transform: scale(1.03);
    }

    /* Shine sweep pseudo-element */
    .button::after,
    .button-secondary::after {
        content: "";
        position: absolute;
        top: 0;
        left: -100%;
        width: 60%;
        height: 100%;
        background: linear-gradient(
            105deg,
            transparent 20%,
            rgb(255 255 255 / 0.2) 45%,
            rgb(255 255 255 / 0.35) 50%,
            rgb(255 255 255 / 0.2) 55%,
            transparent 80%
        );
        transition: none;
        pointer-events: none;
    }

    .button:hover::after,
    .button-secondary:hover::after {
        animation: geekz-btn-shine 0.6s ease-out;
    }

    @keyframes geekz-btn-shine {
        to {
            left: 120%;
        }
    }

    /* Ensure button transform transition is smooth */
    .button,
    .button-secondary {
        transition:
            color var(--animation-speed, 0.2s) var(--animation-easing, ease),
            box-shadow 0.3s ease,
            background-color var(--animation-speed, 0.2s)
                var(--animation-easing, ease),
            transform 0.25s ease-out;
    }

    /* --------------------------------------------------------------------------
     D. Hero CTA — Retro Arcade Pixel Buttons
     Press Start 2P font, orange phosphor glow, scanline texture
     -------------------------------------------------------------------------- */

    .slideshow-section .button,
    .slideshow-section .button-secondary {
        font-family: "Press Start 2P", monospace !important;
        font-size: 10px !important;
        letter-spacing: 0.08em !important;
        text-transform: uppercase !important;
        padding: 16px 28px !important;
        border-radius: 4px !important;
        border: 1px solid rgb(202 64 15 / 0.5) !important;
        box-shadow:
            0 0 8px rgb(202 64 15 / 0.25),
            inset 0 1px 0 rgb(255 255 255 / 0.1);
    }

    .slideshow-section .button {
        background:
            repeating-linear-gradient(
                0deg,
                transparent,
                transparent 2px,
                rgb(0 0 0 / 0.08) 2px,
                rgb(0 0 0 / 0.08) 3px
            ),
            #ca400f !important;
        color: #ffffff !important;
    }

    .slideshow-section .button-secondary {
        background:
            repeating-linear-gradient(
                0deg,
                transparent,
                transparent 2px,
                rgb(202 64 15 / 0.06) 2px,
                rgb(202 64 15 / 0.06) 3px
            ),
            rgba(0, 0, 0, 0.4) !important;
        color: #ca400f !important;
        border: 1px solid rgb(202 64 15 / 0.6) !important;
        backdrop-filter: blur(4px);
    }

    .slideshow-section .button:not(:hover) {
        animation: geekz-pulse 2.5s ease-in-out infinite;
    }

    .slideshow-section .button:hover {
        animation: none;
        background: #b03a0d !important;
        border-color: rgb(202 64 15 / 0.8) !important;
        box-shadow:
            0 0 14px rgb(202 64 15 / 0.5),
            0 0 30px rgb(202 64 15 / 0.15),
            inset 0 1px 0 rgb(255 255 255 / 0.15);
        transform: scale(1.05);
    }

    .slideshow-section .button-secondary:hover {
        animation: none;
        color: #ffffff !important;
        background: rgb(202 64 15 / 0.2) !important;
        border-color: #ca400f !important;
        box-shadow:
            0 0 14px rgb(202 64 15 / 0.4),
            0 0 30px rgb(202 64 15 / 0.1);
        transform: scale(1.05);
    }

    @keyframes geekz-pulse {
        0%,
        100% {
            box-shadow:
                0 0 6px rgb(202 64 15 / 0.2),
                0 0 16px rgb(202 64 15 / 0.06),
                inset 0 1px 0 rgb(255 255 255 / 0.1);
        }
        50% {
            box-shadow:
                0 0 14px rgb(202 64 15 / 0.45),
                0 0 30px rgb(202 64 15 / 0.12),
                inset 0 1px 0 rgb(255 255 255 / 0.1);
        }
    }

    @media screen and (max-width: 749px) {
        .slideshow-section .button,
        .slideshow-section .button-secondary {
            font-size: 8px !important;
            padding: 14px 20px !important;
        }
    }

    /* --------------------------------------------------------------------------
     E. Card Hover — Lift + Glow (border glow is handled in CARDS section)
     -------------------------------------------------------------------------- */

    .product-card,
    .collection-card,
    .resource-card {
        position: relative;
        transition:
            transform var(--hover-transition-duration, 0.25s)
                var(--hover-transition-timing, ease-out),
            box-shadow 0.3s ease-out;
    }

    /* Card lift on hover */
    .product-card:hover,
    .collection-card:hover {
        transform: translateY(-4px);
    }

    /* Softer glow — applied to outer card element */
    .resource-card:hover {
        box-shadow:
            0 4px 16px rgb(var(--color-primary-rgb) / 0.12),
            0 0 1px rgb(var(--color-primary-rgb) / 0.2);
    }

    /* Cart drawer slide-in with neon flash */
    cart-drawer dialog[open] {
        animation: geekz-drawer-in 0.35s cubic-bezier(0.22, 1, 0.36, 1);
    }
    @keyframes geekz-drawer-in {
        0% {
            transform: translateX(100%);
            box-shadow: -4px 0 20px rgb(202 64 15 / 0.4);
        }
        60% {
            box-shadow: -4px 0 30px rgb(202 64 15 / 0.6);
        }
        100% {
            transform: translateX(0);
            box-shadow: none;
        }
    }

    /* Accent line at bottom of card */
    .product-card::after,
    .collection-card::after {
        content: "";
        position: absolute;
        bottom: 0;
        left: 50%;
        width: 0;
        height: 2px;
        background: var(--color-primary);
        box-shadow: 0 0 6px rgb(var(--color-primary-rgb) / 0.35);
        transition:
            width 0.35s cubic-bezier(0.22, 1, 0.36, 1),
            left 0.35s cubic-bezier(0.22, 1, 0.36, 1);
        z-index: 2;
        pointer-events: none;
    }

    .product-card:hover::after,
    .collection-card:hover::after {
        width: 100%;
        left: 0;
    }

    /* --------------------------------------------------------------------------
     F. Scroll-Triggered Reveal Animations
     JS adds .geekz-reveal then .geekz-visible with a frame gap between them
     -------------------------------------------------------------------------- */

    .geekz-reveal {
        opacity: 0 !important;
        transform: translateY(28px);
        transition:
            opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
            transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .geekz-reveal.geekz-visible {
        opacity: 1 !important;
        transform: translateY(0);
    }

    /* Staggered grid items */
    .geekz-stagger > * {
        opacity: 0 !important;
        transform: translateY(20px);
        transition:
            opacity 0.5s cubic-bezier(0.22, 1, 0.36, 1),
            transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .geekz-stagger.geekz-visible > * {
        opacity: 1 !important;
        transform: translateY(0);
    }

    /* Stagger delays for up to 12 children */
    .geekz-stagger.geekz-visible > :nth-child(1) {
        transition-delay: 0ms;
    }
    .geekz-stagger.geekz-visible > :nth-child(2) {
        transition-delay: 80ms;
    }
    .geekz-stagger.geekz-visible > :nth-child(3) {
        transition-delay: 160ms;
    }
    .geekz-stagger.geekz-visible > :nth-child(4) {
        transition-delay: 240ms;
    }
    .geekz-stagger.geekz-visible > :nth-child(5) {
        transition-delay: 320ms;
    }
    .geekz-stagger.geekz-visible > :nth-child(6) {
        transition-delay: 400ms;
    }
    .geekz-stagger.geekz-visible > :nth-child(7) {
        transition-delay: 480ms;
    }
    .geekz-stagger.geekz-visible > :nth-child(8) {
        transition-delay: 560ms;
    }
    .geekz-stagger.geekz-visible > :nth-child(9) {
        transition-delay: 640ms;
    }
    .geekz-stagger.geekz-visible > :nth-child(10) {
        transition-delay: 720ms;
    }
    .geekz-stagger.geekz-visible > :nth-child(11) {
        transition-delay: 800ms;
    }
    .geekz-stagger.geekz-visible > :nth-child(12) {
        transition-delay: 880ms;
    }

    /* --------------------------------------------------------------------------
     J. Marquee Glow Enhancement
     -------------------------------------------------------------------------- */

    .marquee__content {
        text-shadow:
            0 0 6px rgb(var(--color-primary-rgb) / 0.35),
            0 0 18px rgb(var(--color-primary-rgb) / 0.12);
    }

    /* --------------------------------------------------------------------------
     L. Retro Flicker on Section Headings
     Subtle text-shadow opacity dip for a "neon sign" feel
     -------------------------------------------------------------------------- */

    .section :is(h1, h2) {
        animation: geekz-flicker 10s ease-in-out infinite;
    }

    .section h1 {
        animation-delay: 0s;
    }
    .section h2 {
        animation-delay: -3.5s;
    }

    @keyframes geekz-flicker {
        0%,
        3%,
        5%,
        7%,
        41%,
        43%,
        100% {
            text-shadow:
                0 0 8px rgb(var(--color-foreground-heading-rgb) / 0.2),
                0 0 20px rgb(var(--color-foreground-heading-rgb) / 0.06);
        }
        4% {
            text-shadow:
                0 0 4px rgb(var(--color-foreground-heading-rgb) / 0.1),
                0 0 12px rgb(var(--color-foreground-heading-rgb) / 0.03);
        }
        6% {
            text-shadow:
                0 0 6px rgb(var(--color-foreground-heading-rgb) / 0.14),
                0 0 16px rgb(var(--color-foreground-heading-rgb) / 0.05);
        }
        42% {
            text-shadow:
                0 0 3px rgb(var(--color-foreground-heading-rgb) / 0.08),
                0 0 10px rgb(var(--color-foreground-heading-rgb) / 0.02);
        }
    }

    /* --------------------------------------------------------------------------
     M. Glitch Hover on Card Titles
     Brief clip-path glitch when hovering product/collection cards
     -------------------------------------------------------------------------- */

    .resource-card__title,
    .collection-card__content {
        position: relative;
    }

    .product-card:hover .resource-card__title,
    .collection-card:hover .collection-card__content {
        animation: geekz-title-glitch 0.3s ease-out;
    }

    @keyframes geekz-title-glitch {
        0% {
            transform: translateX(0);
        }
        15% {
            transform: translateX(-2px);
            clip-path: inset(10% 0 60% 0);
        }
        30% {
            transform: translateX(2px);
            clip-path: inset(50% 0 20% 0);
        }
        50% {
            transform: translateX(-1px);
            clip-path: inset(30% 0 40% 0);
        }
        70% {
            clip-path: inset(0);
            transform: translateX(0);
        }
        100% {
            transform: translateX(0);
        }
    }

    /* --------------------------------------------------------------------------
     O. CRT Scanline Overlay on Sections
     Even more subtle on light backgrounds
     -------------------------------------------------------------------------- */

    .section:not(.slideshow-section)::before {
        content: "";
        position: absolute;
        inset: 0;
        background: repeating-linear-gradient(
            0deg,
            transparent,
            transparent 3px,
            rgb(0 0 0 / 0.03) 3px,
            rgb(0 0 0 / 0.03) 4px
        );
        pointer-events: none;
        z-index: 1;
    }

    /* --------------------------------------------------------------------------
     P. Image Hover Zoom + Brightness Shift
     -------------------------------------------------------------------------- */

    .collection-card__image,
    .product-card__image,
    .resource-card__image,
    .card-gallery {
        overflow: hidden;
    }

    .collection-card__image img,
    .product-card__image img,
    .resource-card__image img,
    .card-gallery img {
        transition:
            transform 0.4s cubic-bezier(0.22, 1, 0.36, 1),
            filter 0.4s ease;
    }

    .collection-card:hover img,
    .product-card:hover img,
    .resource-card:hover img {
        transform: scale(1.06);
        filter: brightness(1.05);
    }

    /* --------------------------------------------------------------------------
     Q. Blinking Cursor on Hero Subtext
     Terminal-style blinking pipe after the subtitle
     -------------------------------------------------------------------------- */

    .slideshow-section .slide__content p {
        position: relative;
        display: inline-block;
    }

    .slideshow-section .slide__content p::after {
        content: "|";
        color: var(--color-primary, #0066ff);
        font-weight: 100;
        animation: geekz-blink 1s step-end infinite;
        margin-inline-start: 2px;
        text-shadow: 0 0 4px rgb(var(--color-primary-rgb) / 0.4);
    }

    @keyframes geekz-blink {
        0%,
        100% {
            opacity: 1;
        }
        50% {
            opacity: 0;
        }
    }

    /* --------------------------------------------------------------------------
     R. Footer Social/Icon Link Glow on Hover
     -------------------------------------------------------------------------- */

    #footer-group .section a:has(svg):hover {
        filter: drop-shadow(0 0 3px rgb(var(--color-primary-rgb) / 0.4));
        transform: scale(1.15);
        transition:
            filter 0.25s ease,
            transform 0.25s ease;
    }

    /* --------------------------------------------------------------------------
     S. Announcement Bar Text Glow
     White glow on the orangy-red bar
     -------------------------------------------------------------------------- */

    .announcement-bar {
        text-shadow: 0 0 8px rgb(255 255 255 / 0.35);
    }

    /* --------------------------------------------------------------------------
     T. Chromatic Aberration on Product Image Hover
     Subtle RGB split like a misaligned CRT tube
     -------------------------------------------------------------------------- */

    .product-card:hover img,
    .collection-card:hover img {
        filter: brightness(1.05);
        animation: geekz-chromatic 0.35s ease-out forwards;
    }

    @keyframes geekz-chromatic {
        0% {
            filter: brightness(1.05);
        }
        30% {
            filter: brightness(1.05) drop-shadow(-2px 0 0 rgb(202 64 15 / 0.4))
                drop-shadow(2px 0 0 rgb(0 102 255 / 0.4));
        }
        100% {
            filter: brightness(1.05) drop-shadow(-1px 0 0 rgb(202 64 15 / 0.15))
                drop-shadow(1px 0 0 rgb(0 102 255 / 0.15));
        }
    }

    /* --------------------------------------------------------------------------
     U. CRT Power-On Section Reveal
     Sections animate in like an old TV turning on — horizontal line expanding
     -------------------------------------------------------------------------- */

    .geekz-reveal.geekz-crt-on {
        opacity: 0 !important;
        transform: none;
        clip-path: inset(50% 0 50% 0);
        transition:
            opacity 0.1s ease,
            clip-path 0.5s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .geekz-reveal.geekz-crt-on.geekz-visible {
        opacity: 1 !important;
        clip-path: inset(0 0 0 0);
    }

    /* --------------------------------------------------------------------------
     V. VHS Tracking Band
     Horizontal distortion band sweeps down once on section reveal
     -------------------------------------------------------------------------- */

    .geekz-reveal.geekz-visible::after {
        content: "";
        position: absolute;
        left: 0;
        top: -10%;
        width: 100%;
        height: 6px;
        background: linear-gradient(
            180deg,
            transparent,
            rgb(255 255 255 / 0.08) 30%,
            rgb(255 255 255 / 0.15) 50%,
            rgb(255 255 255 / 0.08) 70%,
            transparent
        );
        filter: blur(1px);
        pointer-events: none;
        z-index: 10;
        animation: geekz-vhs-track 0.8s ease-out 0.1s forwards;
        opacity: 0;
    }

    @keyframes geekz-vhs-track {
        0% {
            top: -10%;
            opacity: 1;
        }
        80% {
            opacity: 0.6;
        }
        100% {
            top: 110%;
            opacity: 0;
        }
    }

    /* --------------------------------------------------------------------------
     V2. Arcade Bezel on Hero Slideshow
     Inner shadow simulating arcade monitor housing
     -------------------------------------------------------------------------- */

    .slideshow-section {
        box-shadow:
            inset 0 0 80px rgb(0 0 0 / 0.5),
            inset 0 0 20px rgb(0 0 0 / 0.3);
    }

    /* Rounded screen corners inside the hero */
    .slideshow-section .slideshow {
        border-radius: 6px;
    }

    /* --------------------------------------------------------------------------
     V3. Retro Achievement Toast Styling
     Xbox 360-style "Achievement Unlocked" popups
     -------------------------------------------------------------------------- */

    .geekz-achievement {
        position: fixed;
        bottom: 24px;
        right: 24px;
        z-index: 9999;
        display: flex;
        align-items: center;
        gap: 14px;
        padding: 14px 22px;
        background: linear-gradient(135deg, #1a1a1a 0%, #2a2a2a 100%);
        border: 2px solid var(--color-primary, #ca400f);
        border-radius: 8px;
        box-shadow:
            0 0 12px rgb(202 64 15 / 0.3),
            0 0 30px rgb(202 64 15 / 0.1),
            0 4px 20px rgb(0 0 0 / 0.5);
        color: #fff;
        font-family: "Orbitron", sans-serif;
        transform: translateX(120%);
        transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
        pointer-events: none;
        max-width: 360px;
    }

    .geekz-achievement.is-visible {
        transform: translateX(0);
    }

    .geekz-achievement__icon {
        font-size: 1.8rem;
        flex-shrink: 0;
        filter: drop-shadow(0 0 6px rgb(255 215 0 / 0.5));
    }

    .geekz-achievement__body {
        display: flex;
        flex-direction: column;
        gap: 2px;
    }

    .geekz-achievement__label {
        font-size: 0.6rem;
        font-weight: 700;
        letter-spacing: 0.15em;
        text-transform: uppercase;
        color: #ffd700;
        text-shadow: 0 0 6px rgb(255 215 0 / 0.4);
    }

    .geekz-achievement__title {
        font-size: 0.85rem;
        font-weight: 500;
        letter-spacing: 0.04em;
        color: #e0e0e0;
    }

    /* Scanline across the toast */
    .geekz-achievement::before {
        content: "";
        position: absolute;
        inset: 0;
        border-radius: 6px;
        background: repeating-linear-gradient(
            0deg,
            transparent,
            transparent 2px,
            rgb(0 0 0 / 0.06) 2px,
            rgb(0 0 0 / 0.06) 3px
        );
        pointer-events: none;
    }

    @media screen and (max-width: 749px) {
        .geekz-achievement {
            bottom: 16px;
            right: 12px;
            left: 12px;
            max-width: none;
        }
    }

    /* --------------------------------------------------------------------------
     V4. Konami Code Reward Overlay
     Full-screen retro celebration when code is entered
     -------------------------------------------------------------------------- */

    .geekz-konami-overlay {
        position: fixed;
        inset: 0;
        z-index: 99999;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        background: rgb(0 0 0 / 0.92);
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.4s ease;
    }

    .geekz-konami-overlay.is-active {
        opacity: 1;
        pointer-events: auto;
    }

    .geekz-konami-overlay__text {
        font-family: "Orbitron", sans-serif;
        font-size: clamp(1.6rem, 5vw, 3.2rem);
        font-weight: 900;
        color: #ffd700;
        text-shadow:
            0 0 20px rgb(255 215 0 / 0.6),
            0 0 60px rgb(255 215 0 / 0.2);
        text-align: center;
        animation: geekz-konami-pulse 1.2s ease-in-out infinite;
    }

    .geekz-konami-overlay__sub {
        font-family: "Orbitron", sans-serif;
        font-size: clamp(0.8rem, 2vw, 1.1rem);
        color: #e0e0e0;
        margin-top: 16px;
        letter-spacing: 0.1em;
        text-align: center;
    }

    @keyframes geekz-konami-pulse {
        0%,
        100% {
            text-shadow:
                0 0 20px rgb(255 215 0 / 0.6),
                0 0 60px rgb(255 215 0 / 0.2);
        }
        50% {
            text-shadow:
                0 0 30px rgb(255 215 0 / 0.8),
                0 0 80px rgb(255 215 0 / 0.35),
                0 0 120px rgb(202 64 15 / 0.15);
        }
    }

    /* --------------------------------------------------------------------------
     V5. Sound Toggle Button in Header
     Tiny retro speaker icon; toggles arcade SFX
     -------------------------------------------------------------------------- */

    .geekz-sfx-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
        width: var(--button-size, 44px);
        height: var(--button-size, 44px);
        background: transparent;
        border: none;
        padding: 0;
        color: var(--color-foreground, #d0d0d0);
        cursor: pointer;
        flex-shrink: 0;
        transition: opacity var(--animation-speed, 0.2s)
            var(--animation-easing, ease);
    }

    @media screen and (max-width: 749px) {
        .geekz-sfx-toggle {
            width: 32px;
            height: 32px;
            margin-inline-end: -4px;
        }
    }

    .geekz-sfx-toggle:hover {
        opacity: var(--opacity-subdued-text, 0.6);
    }

    .geekz-sfx-toggle svg {
        width: var(--icon-size-md, 1.25rem);
        height: var(--icon-size-md, 1.25rem);
    }

    .geekz-sfx-toggle.is-muted {
        opacity: 0.35;
    }

    /* ---------- end reduced-motion gate ---------- */
}

/* ==========================================================================
   Effects that are NOT motion-dependent (always applied)
   ========================================================================== */

/* --------------------------------------------------------------------------
   H. Custom Retro Scrollbar
   Adapted for light theme backgrounds
   -------------------------------------------------------------------------- */

:root {
    scrollbar-color: var(--color-primary) rgb(var(--color-background-rgb) / 0.3);
    scrollbar-width: thin;
}

::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: rgb(30 30 30 / 0.6);
}

::-webkit-scrollbar-thumb {
    background: var(--color-primary);
    border-radius: 3px;
    box-shadow: 0 0 4px rgb(var(--color-primary-rgb) / 0.3);
}

::-webkit-scrollbar-thumb:hover {
    background: var(--color-primary-hover, var(--color-primary));
}

/* --------------------------------------------------------------------------
   I. Selection Highlight
   -------------------------------------------------------------------------- */

::selection {
    background: rgb(var(--color-primary-rgb) / 0.2);
    color: var(--color-foreground);
}

::-moz-selection {
    background: rgb(var(--color-primary-rgb) / 0.2);
    color: var(--color-foreground);
}

/* --------------------------------------------------------------------------
   BADGES. Product Badge System — Press Start 2P + 6 Types
   Tag-based: products tagged "new", "rare", "pre-order", "limited"
   -------------------------------------------------------------------------- */

.product-badges__badge {
    font-family: "Press Start 2P", monospace !important;
    font-size: 9px !important;
    font-weight: 400 !important;
    letter-spacing: 0.05em;
    padding: 4px 10px !important;
    text-transform: uppercase !important;
    border-radius: 2px !important;
    line-height: 1.6;
}

/* Badge type colors */
.product-badges__badge--new {
    background: #f0e84d !important;
    color: #0d0d1a !important;
}
.product-badges__badge--sale {
    background: #ca400f !important;
    color: #ffffff !important;
}
.product-badges__badge--rare {
    background: #ffd700 !important;
    color: #0d0d1a !important;
}
.product-badges__badge--sold-out {
    background: #ff2941 !important;
    color: #ffffff !important;
}
.product-badges__badge--pre-order {
    background: #bf5fff !important;
    color: #ffffff !important;
}
.product-badges__badge--limited {
    background: #ff6600 !important;
    color: #ffffff !important;
}

/* RARE badge pulse glow */
@media (prefers-reduced-motion: no-preference) {
    .product-badges__badge--rare {
        animation: geekz-rare-pulse 2s ease-in-out infinite;
    }
    @keyframes geekz-rare-pulse {
        0%,
        100% {
            box-shadow: 0 0 4px rgb(255 215 0 / 0.3);
        }
        50% {
            box-shadow:
                0 0 12px rgb(255 215 0 / 0.6),
                0 0 24px rgb(255 215 0 / 0.2);
        }
    }

    /* LIMITED badge subtle flicker */
    .product-badges__badge--limited {
        animation: geekz-limited-flicker 3s ease-in-out infinite;
    }
    @keyframes geekz-limited-flicker {
        0%,
        100% {
            opacity: 1;
        }
        50% {
            opacity: 0.85;
        }
        52% {
            opacity: 1;
        }
    }
}

/* Sold-out product treatment — grayscale image + reduced brightness */
.product-card:has(.product-badges__badge--sold-out) img {
    filter: grayscale(60%) brightness(0.7);
    transition: filter 0.3s ease;
}
.product-card:has(.product-badges__badge--sold-out):hover img {
    filter: grayscale(30%) brightness(0.85);
}

/* --------------------------------------------------------------------------
   FOOTER. Neon Divider + Grid Pattern + Newsletter Treatment
   -------------------------------------------------------------------------- */

/* Footer neon top border */
#footer-group .footer {
    position: relative;
    border-top: 1px solid rgb(202 64 15 / 0.3);
    box-shadow: 0 -1px 8px rgb(202 64 15 / 0.15);
}

/* Subtle grid pattern on footer group */
#footer-group {
    background-image:
        linear-gradient(rgb(255 255 255 / 0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgb(255 255 255 / 0.02) 1px, transparent 1px);
    background-size: 40px 40px;
}

/* Newsletter section retro treatment */
#footer-group .section:first-child {
    position: relative;
    border-bottom: 1px solid rgb(202 64 15 / 0.2);
}
#footer-group .section:first-child::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(
        ellipse at center,
        rgb(202 64 15 / 0.04) 0%,
        transparent 70%
    );
    pointer-events: none;
    z-index: 0;
}

/* --------------------------------------------------------------------------
   CAT. Category-Specific Collection Page Theming
   Uses Shopify's body[data-template] + handle injected via theme.liquid
   -------------------------------------------------------------------------- */

body[data-collection="die-cast"] .main-collection {
    --color-primary: #ff6600;
    --color-primary-rgb: 255 102 0;
}
body[data-collection="die-cast"] .section h1,
body[data-collection="die-cast"] .section h2 {
    color: #ff6600;
    text-shadow: 0 0 8px rgb(255 102 0 / 0.3);
}

body[data-collection="gaming"] .main-collection {
    --color-primary: #39ff14;
    --color-primary-rgb: 57 255 20;
}
body[data-collection="gaming"] .section h1,
body[data-collection="gaming"] .section h2 {
    color: #39ff14;
    text-shadow: 0 0 8px rgb(57 255 20 / 0.3);
}

body[data-collection="figures"] .main-collection {
    --color-primary: #0066ff;
    --color-primary-rgb: 0 102 255;
}
body[data-collection="figures"] .section h1,
body[data-collection="figures"] .section h2 {
    color: #0066ff;
    text-shadow: 0 0 8px rgb(0 102 255 / 0.3);
}

body[data-collection="comics"] .main-collection {
    --color-primary: #bf5fff;
    --color-primary-rgb: 191 95 255;
}
body[data-collection="comics"] .section h1,
body[data-collection="comics"] .section h2 {
    color: #bf5fff;
    text-shadow: 0 0 8px rgb(191 95 255 / 0.3);
}

body[data-collection="coins"] .main-collection {
    --color-primary: #ffd700;
    --color-primary-rgb: 255 215 0;
}
body[data-collection="coins"] .section h1,
body[data-collection="coins"] .section h2 {
    color: #ffd700;
    text-shadow: 0 0 8px rgb(255 215 0 / 0.3);
}

body[data-collection="paintings-posters"] .main-collection {
    --color-primary: #ca400f;
    --color-primary-rgb: 202 64 15;
}
body[data-collection="paintings-posters"] .section h1,
body[data-collection="paintings-posters"] .section h2 {
    color: #ca400f;
    text-shadow: 0 0 8px rgb(202 64 15 / 0.3);
}

body[data-collection="music"] .main-collection {
    --color-primary: #0066ff;
    --color-primary-rgb: 0 102 255;
}
body[data-collection="music"] .section h1,
body[data-collection="music"] .section h2 {
    color: #0066ff;
    text-shadow: 0 0 8px rgb(0 102 255 / 0.3);
}

body[data-collection="building-sets"] .main-collection {
    --color-primary: #f0e84d;
    --color-primary-rgb: 240 232 77;
}
body[data-collection="building-sets"] .section h1,
body[data-collection="building-sets"] .section h2 {
    color: #f0e84d;
    text-shadow: 0 0 8px rgb(240 232 77 / 0.3);
}

body[data-collection="miscellaneous"] .main-collection {
    --color-primary: #b0a8ff;
    --color-primary-rgb: 176 168 255;
}
body[data-collection="miscellaneous"] .section h1,
body[data-collection="miscellaneous"] .section h2 {
    color: #b0a8ff;
    text-shadow: 0 0 8px rgb(176 168 255 / 0.3);
}

/* --------------------------------------------------------------------------
   404. Custom 404 Page Retro Styling
   -------------------------------------------------------------------------- */

.template-404 .main-404 {
    position: relative;
}

.template-404 .main-404 h1 {
    font-family: "Orbitron", sans-serif !important;
    font-weight: 900;
    letter-spacing: 0.1em;
    text-shadow:
        0 0 10px rgb(202 64 15 / 0.5),
        0 0 30px rgb(202 64 15 / 0.2);
}

/* 404 error subtext in pixel font */
.template-404 .main-404 p:first-of-type {
    font-family: "Press Start 2P", monospace !important;
    font-size: 10px;
    letter-spacing: 0.08em;
    color: #ca400f;
    text-shadow: 0 0 6px rgb(202 64 15 / 0.3);
}

/* ==========================================================================
   CARDS. Dark Bordered Card Redesign — Collectibles Auction House Style
   Consistent heights, dark containers, pixel-font buttons, premium look
   ========================================================================== */

/* --------------------------------------------------------------------------
   CARDS-1. Product Card Container — Dark Background + Border
   -------------------------------------------------------------------------- */

.product-card .product-card__content.product-grid__card {
    background: #1a1a1a !important;
    border: 1px solid rgb(202 64 15 / 0.15) !important;
    border-radius: 8px !important;
    overflow: hidden;
    transition:
        border-color 0.3s ease,
        box-shadow 0.3s ease;
    /* Flex column for content ordering */
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    /* Reserve fixed space at bottom for the GRAB button (absolute positioned) */
    position: relative !important;
    padding-bottom: 68px !important;
}

/* Product card wrappers fill height so cards are equal height in a row.
   Scoped to product-card only — NOT collection cards.
   The :has(product-card-link) ensures collection cards keep their default layout. */
.resource-list__item:has(product-card-link) {
    display: flex !important;
    flex-direction: column !important;
}

product-card-link:has(> product-card) {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 !important;
}

/* Override theme's :is(.product-grid__item, .resource-list__item) .product-card { display: grid }
   which has specificity (0,2,0). We need at least (0,2,0) + !important. */
.product-grid__item product-card.product-card,
.resource-list__item product-card.product-card {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 !important;
    height: 100% !important;
}

/* Border glow on hover */
.product-card:hover .product-card__content.product-grid__card {
    border-color: rgb(202 64 15 / 0.45) !important;
    box-shadow: 0 0 16px rgb(202 64 15 / 0.1);
}

/* Remove grid-item level border (theme default) — our border is on the inner content */
.product-grid__item {
    border: none !important;
    display: flex !important;
    flex-direction: column !important;
}

/* --------------------------------------------------------------------------
   CARDS-2. Image Area — Consistent Square Ratio + Dark Background
   -------------------------------------------------------------------------- */

/* Force square ratio on product card images */
.product-card .card-gallery {
    --gallery-aspect-ratio: 1 / 1 !important;
    background: #111111;
    border-radius: 0 !important;
}

/* Ensure slideshow/images respect the forced ratio */
.product-card .card-gallery slideshow-component,
.product-card .card-gallery .slideshow {
    aspect-ratio: 1 / 1;
}

.product-card .card-gallery img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

/* Placeholder SVGs — dark background */
.product-card .card-gallery__placeholder svg,
.card-gallery svg {
    background: #1a1a1a;
}

/* --------------------------------------------------------------------------
   CARDS-3. Title & Price Content Area — Padding + Truncation
   -------------------------------------------------------------------------- */

/* Title block — padding inside the dark card.
   Live DOM: <a class="contents"> → <div class="spacing-style text-block rte ...">
   The <a> has display:contents, so we target the inner div directly.
   Use .rte to distinguish title from product-price (which also has .text-block).
   Use padding-block/padding-inline (logical properties) to directly override
   .spacing-style which also uses logical properties via CSS custom vars. */
.product-card__content.product-grid__card .text-block.rte {
    --padding-block-start: 14px !important;
    --padding-block-end: 0px !important;
    --padding-inline-start: 18px !important;
    --padding-inline-end: 18px !important;
    padding-block: 14px 0 !important;
    padding-inline: 18px !important;
}

/* Price block — horizontal padding + smaller top spacing.
   Live DOM: <product-price class="text-block spacing-style ..."> (direct child).
   Override CSS custom vars AND logical properties for certainty. */
.product-card__content.product-grid__card product-price,
.product-card__content.product-grid__card product-price.text-block {
    --padding-block-start: 4px !important;
    --padding-block-end: 0px !important;
    --padding-inline-start: 18px !important;
    --padding-inline-end: 18px !important;
    padding-block: 4px 0 !important;
    padding-inline: 18px !important;
}

/* Truncate product title to 2 lines for consistent card height */
.product-card__content .text-block p,
.product-card__content rte-formatter p {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    line-height: 1.4;
    min-height: calc(2 * 1.4em);
    margin: 0;
}

/* Title text color */
.product-card__content .text-block p,
.product-card__content rte-formatter p {
    color: #f0f0f0;
}

/* Global: actual price always white for clarity */
.price { color: #ffffff; }

/* Price emphasis — larger & bolder to distinguish from title */
.product-card__content product-price {
    color: #ffffff;
    font-weight: 700;
    font-size: 1.15rem;
}

.product-card__content product-price .price {
    font-size: 1.35rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}

/* Compare-at (strikethrough) price — dimmed */
.product-card__content product-price .compare-at-price {
    color: rgb(255 255 255 / 0.45);
    font-size: 0.9rem;
    font-weight: 400;
}

/* --------------------------------------------------------------------------
   CARDS-4. Quick-Add "GRAB" Button — Full-Width Pixel-Font at Card Bottom
   Nuclear overrides: every sub-element targeted to defeat embedded stylesheet
   -------------------------------------------------------------------------- */

/* ---- 4a. HIDE the Choose button (double-class for max specificity) ---- */
.product-card .quick-add .quick-add__button.quick-add__button--choose,
.product-card .quick-add button.quick-add__button--choose,
.product-card quick-add-component .quick-add__button--choose {
    display: none !important;
    visibility: hidden !important;
    width: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
    position: absolute !important;
    pointer-events: none !important;
}

/* ---- 4b. Force add-to-cart-component visible on multi-variant products ---- */
.product-card .quick-add[data-quick-add-button="choose"] add-to-cart-component,
.product-card
    quick-add-component[data-quick-add-button="choose"]
    add-to-cart-component {
    display: block !important;
}

/* ---- 4c. Container: absolute positioned at the bottom of the card ---- */
/* Using absolute positioning instead of margin-top:auto ensures GRAB buttons
   are always at the exact same vertical position regardless of title length,
   price format, or "Make an Offer" app injection outside the card. */
.product-card .quick-add,
.product-card quick-add-component.quick-add {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    top: unset !important;
    width: 100% !important;
    padding: 10px 18px 14px !important;
    pointer-events: auto !important;
    display: block !important;
    z-index: 2 !important;
    margin-top: 0 !important;
    background-color: transparent !important;
}

/* ---- 4d. Form wrappers — full width, no flex-end alignment ---- */
.product-card .quick-add .quick-add__product-form-component,
.product-card .quick-add product-form-component {
    width: 100% !important;
    height: auto !important;
    display: block !important;
}

.product-card .quick-add form,
.product-card .quick-add .shopify-product-form {
    width: 100% !important;
    display: block !important;
    justify-content: stretch !important;
    align-items: stretch !important;
    container-type: normal !important;
    height: auto !important;
}

.product-card .quick-add add-to-cart-component {
    display: block !important;
    width: 100% !important;
}

/* ---- 4e. The GRAB button ---- */
.product-card .quick-add .quick-add__button.quick-add__button--add,
.product-card .quick-add button.quick-add__button--add {
    position: static !important;
    inset: unset !important;
    top: unset !important;
    right: unset !important;
    bottom: unset !important;
    left: unset !important;
    display: flex !important;
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    background: #ca400f !important;
    color: #ffffff !important;
    border: 1px solid rgb(255 102 0 / 0.3) !important;
    border-radius: 4px !important;
    font-family: "Press Start 2P", monospace !important;
    font-size: 9px !important;
    letter-spacing: 0.03em !important;
    padding: 14px 12px !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 8px !important;
    opacity: 1 !important;
    backdrop-filter: none !important;
    cursor: pointer !important;
    transition:
        background 0.2s ease,
        box-shadow 0.2s ease,
        transform 0.15s ease !important;
    pointer-events: auto !important;
    overflow: visible !important;
    text-transform: uppercase !important;
    scale: 1 !important;
    translate: none !important;
}

/* Hover */
.product-card .quick-add .quick-add__button.quick-add__button--add:hover {
    background: #b03a0d !important;
    box-shadow: 0 0 12px rgb(202 64 15 / 0.3) !important;
    scale: 1 !important;
}

.product-card .quick-add .quick-add__button.quick-add__button--add:active {
    background: #963210 !important;
    scale: 0.98 !important;
}

/* Disabled (sold out) */
.product-card .quick-add .quick-add__button.quick-add__button--add:disabled {
    background: #333 !important;
    border-color: rgb(255 255 255 / 0.1) !important;
    color: rgb(255 255 255 / 0.4) !important;
    cursor: not-allowed !important;
}

/* ---- 4f. Inner text wrapper (.add-to-cart-text) ---- */
.product-card .quick-add .quick-add__button--add .add-to-cart-text {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    background: transparent !important;
    border-radius: 0 !important;
    height: auto !important;
    overflow: visible !important;
    width: auto !important;
    padding: 0 !important;
    clip-path: none !important;
    opacity: 1 !important;
    filter: none !important;
    translate: none !important;
}

/* ---- 4g. Text content grid — force 1fr (theme sets 0fr to hide text) ---- */
.product-card .quick-add .quick-add__button--add .add-to-cart-text__content,
.product-card
    .quick-add
    .quick-add__button--add
    .add-to-cart-text__content.is-visually-hidden-mobile {
    display: block !important;
    grid-template-columns: 1fr !important;
    clip: unset !important;
    clip-path: none !important;
    position: static !important;
    width: auto !important;
    height: auto !important;
    overflow: visible !important;
    white-space: nowrap !important;
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    opacity: 1 !important;
}

/* ---- 4h. Inner spans — theme hides these with opacity:0 + blur ---- */
.product-card
    .quick-add
    .quick-add__button--add
    .add-to-cart-text__content
    span,
.product-card
    .quick-add
    .quick-add__button--add
    .add-to-cart-text__content
    span
    span {
    opacity: 1 !important;
    filter: none !important;
    translate: none !important;
    display: inline !important;
    min-width: unset !important;
    padding: 0 !important;
    visibility: visible !important;
}

/* ---- 4i. Cart icon — small and white ---- */
.product-card .quick-add .quick-add__button--add .add-to-cart-icon {
    width: 16px !important;
    height: 16px !important;
    flex-shrink: 0 !important;
    display: flex !important;
    align-items: center !important;
}
.product-card .quick-add .quick-add__button--add .add-to-cart-icon svg {
    width: 16px !important;
    height: 16px !important;
}

/* ---- 4j. Checkmark animation — release locks when added ---- */
.product-card .quick-add .add-to-cart__added {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    translate: -50% -50% !important;
    transform: none !important;
}

.product-card .quick-add .quick-add__button--add[data-added='true'] .add-to-cart-text {
    visibility: hidden !important;
    opacity: 0 !important;
}

.product-card .quick-add .quick-add__button--add[data-added='true'] .add-to-cart-text *,
.product-card .quick-add .quick-add__button--add[data-added='true'] .add-to-cart-text__content,
.product-card .quick-add .quick-add__button--add[data-added='true'] .add-to-cart-text__content span,
.product-card .quick-add .quick-add__button--add[data-added='true'] .add-to-cart-text__content span span {
    visibility: hidden !important;
    opacity: 0 !important;
}

/* ---- 4k. Hover text expansion from theme — disable it ---- */
.product-card
    .quick-add
    .quick-add__button--add:hover
    .add-to-cart-text__content,
.product-card
    .quick-add
    .quick-add__button--add:focus-visible
    .add-to-cart-text__content {
    grid-template-columns: 1fr !important;
}
.product-card
    .quick-add
    .quick-add__button--add:hover
    .add-to-cart-text__content
    span
    span,
.product-card
    .quick-add
    .quick-add__button--add:focus-visible
    .add-to-cart-text__content
    span
    span {
    opacity: 1 !important;
    translate: none !important;
    filter: none !important;
}

/* ---- 4l. Transition overrides — no slide/blur transitions on text ---- */
.product-card .quick-add .quick-add__button--add .add-to-cart-text__content,
.product-card
    .quick-add
    .quick-add__button--add
    .add-to-cart-text__content
    span
    span {
    transition: none !important;
}

/* Product card hover should NOT change button opacity ---- */
product-card:is(:hover, :focus-within)
    .product-card__content
    .quick-add__button--add {
    opacity: 1 !important;
}

/* --------------------------------------------------------------------------
   CARDS-5. Collection Card — Dark Background + Border + Consistent Images
   -------------------------------------------------------------------------- */

.collection-card {
    background: #1a1a1a !important;
    border: 1px solid rgb(202 64 15 / 0.15) !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    transition:
        border-color 0.3s ease,
        box-shadow 0.3s ease;
}

/* Border glow on hover */
.collection-card:hover {
    border-color: rgb(202 64 15 / 0.45) !important;
    box-shadow: 0 0 16px rgb(202 64 15 / 0.1);
}

.collection-card .collection-card__inner {
    background: #1a1a1a !important;
}

/* Force consistent image ratio on collection images */
.collection-card .collection-card__image {
    aspect-ratio: 1 / 1 !important;
    background: #111111 !important;
    overflow: hidden;
}

.collection-card .collection-card__image img,
.collection-card .collection-card__image .image-block__image {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

/* Placeholder SVGs — dark background */
.collection-card .collection-card__image svg,
.collection-card > svg {
    background: #1a1a1a;
}

/* Collection card content (title area) — padding + flex column for EXPLORE button */
.collection-card .collection-card__content {
    padding: 12px 14px !important;
    flex-direction: column !important;
    box-sizing: border-box !important;
}

/* Collection title text styling */
.collection-card .collection-card__content .text-block,
.collection-card .collection-card__content rte-formatter {
    color: #f0f0f0;
}

.collection-card .collection-card__content .text-block p,
.collection-card .collection-card__content rte-formatter p {
    color: #f0f0f0;
    font-weight: 600;
    margin: 0;
}

/* "EXPLORE" pseudo-button under collection title */
.collection-card .collection-card__content::after {
    content: "EXPLORE";
    display: block;
    width: auto;
    align-self: stretch;
    margin-top: 10px;
    padding: 10px 12px;
    background: rgb(202 64 15 / 0.12);
    border: 1px solid rgb(202 64 15 / 0.25);
    border-radius: 4px;
    color: #ca400f;
    font-family: "Press Start 2P", monospace;
    font-size: 8px;
    letter-spacing: 0.05em;
    text-align: center;
    text-transform: uppercase;
    transition:
        background 0.2s ease,
        color 0.2s ease;
}

/* Collection "button" hover — fills with color */
.collection-card:hover .collection-card__content::after {
    background: #ca400f;
    color: #ffffff;
    border-color: #ca400f;
}

/* --------------------------------------------------------------------------
   CARDS-6. Override Existing Card Effects for New Design
   Remove the accent-line ::after since cards now have visible borders.
   The card-lift and image-zoom effects remain.
   -------------------------------------------------------------------------- */

/* Disable the old accent line on product-card */
.product-card::after {
    display: none !important;
}

/* Disable old accent line on collection-card (replaced by border glow + EXPLORE button).
   The new "EXPLORE" pseudo-button lives on .collection-card__content::after (different element). */
.collection-card::after {
    content: none !important;
    display: none !important;
}

/* Ensure the image zoom stays scoped inside .card-gallery / .collection-card__image */
.product-card .card-gallery {
    overflow: hidden;
}

/* --------------------------------------------------------------------------
   CARDS-6b. Collection/Page Description — Force White Text
   The collection description in Shopify admin has inline style="color: #333333"
   baked into the rich-text HTML. No JSON setting can override inline styles.
   -------------------------------------------------------------------------- */

/* Override inline color: #333333 in collection/page description text */
.color-scheme-1 .text-block.rte p,
.color-scheme-1 .text-block.rte p span,
.color-scheme-1 .text-block.rte p span[style] {
    color: #ffffff !important;
}

/* --------------------------------------------------------------------------
   CARDS-6c. "Make an Offer" App Button — Spacing from GRAB
   The app injects <button class="mao-collection-offer-button"> as a direct
   child of .product-card__content (the flex-column container).
   GRAB (quick-add) is position:absolute at bottom:0, occupying ~63px.
   We absolute-position the offer button above GRAB.
   -------------------------------------------------------------------------- */

/* Position Make an Offer button above GRAB.
   GRAB quick-add container: 10px pad-top + ~39px button + 14px pad-bottom = ~63px.
   Set bottom: 68px to clear GRAB with a 5px visual gap. */
.product-card__content .mao-collection-offer-button,
.product-card .mao-collection-offer-button,
.product-grid__card .mao-collection-offer-button {
    position: absolute !important;
    bottom: 68px !important;
    left: 18px !important;
    right: 18px !important;
    width: auto !important;
    margin: 0 !important;
    padding: 10px 14px !important;
    z-index: 3 !important;
    box-sizing: border-box !important;
    font-family: "Press Start 2P", monospace !important;
    font-size: 8px !important;
    letter-spacing: 0.03em !important;
    text-transform: uppercase !important;
    text-align: center !important;
    background: rgb(202 64 15 / 0.12) !important;
    color: #ca400f !important;
    border: 1px solid rgb(202 64 15 / 0.3) !important;
    border-radius: 4px !important;
    cursor: pointer !important;
    transition:
        background 0.2s ease,
        color 0.2s ease,
        box-shadow 0.2s ease !important;
}

.product-card__content .mao-collection-offer-button:hover,
.product-card .mao-collection-offer-button:hover {
    background: #ca400f !important;
    color: #ffffff !important;
    border-color: #ca400f !important;
    box-shadow: 0 0 10px rgb(202 64 15 / 0.3) !important;
}

/* Cards WITH Make an Offer need more bottom padding to contain both buttons.
   68px (MAO bottom offset) + ~42px (MAO button height) ≈ 110—round to 116px. */
.product-card__content.product-grid__card:has(.mao-collection-offer-button) {
    padding-bottom: 116px !important;
}

/* --------------------------------------------------------------------------
   CARDS-7. Mobile Refinements
   -------------------------------------------------------------------------- */

@media screen and (max-width: 749px) {
    /* Slightly smaller padding on mobile — same logical-property approach */
    .product-card__content.product-grid__card .text-block.rte {
        --padding-block-start: 12px !important;
        --padding-inline-start: 14px !important;
        --padding-inline-end: 14px !important;
        padding-block: 12px 0 !important;
        padding-inline: 14px !important;
    }

    .product-card__content.product-grid__card product-price,
    .product-card__content.product-grid__card product-price.text-block {
        --padding-block-start: 2px !important;
        --padding-inline-start: 14px !important;
        --padding-inline-end: 14px !important;
        padding-block: 2px 0 !important;
        padding-inline: 14px !important;
    }

    /* Slightly smaller price on mobile */
    .product-card__content product-price .price {
        font-size: 1.2rem;
    }

    .product-card .quick-add {
        padding: 8px 14px 10px !important;
    }

    /* Smaller reserved space for button on mobile */
    .product-card .product-card__content.product-grid__card {
        padding-bottom: 56px !important;
    }

    /* Cards WITH Make an Offer need more space on mobile.
       Mobile GRAB area ≈ 50px (8+32+10). MAO at bottom: 66px gives ~16px gap. */
    .product-card
        .product-card__content.product-grid__card:has(
            .mao-collection-offer-button
        ) {
        padding-bottom: 112px !important;
    }

    .product-card__content .mao-collection-offer-button,
    .product-card .mao-collection-offer-button {
        bottom: 66px !important;
        left: 14px !important;
        right: 14px !important;
        padding: 8px 10px !important;
        font-size: 7px !important;
    }

    /* Smaller button on mobile */
    .product-card .quick-add .quick-add__button--add {
        font-size: 8px !important;
        padding: 12px 8px !important;
    }

    /* Smaller collection card content */
    .collection-card .collection-card__content {
        padding: 8px 10px !important;
    }

    .collection-card .collection-card__content::after {
        font-size: 7px;
        padding: 8px 8px;
        margin-top: 6px;
    }

    /* Title: show only 1 line on small mobile to save space */
    .product-card__content .text-block p,
    .product-card__content rte-formatter p {
        -webkit-line-clamp: 2;
        min-height: calc(2 * 1.4em);
        font-size: 0.85rem;
    }
}

/* Extra small screens */
@media screen and (max-width: 479px) {
    .product-card .quick-add .quick-add__button--add {
        font-size: 7px !important;
        padding: 10px 6px !important;
    }
}

/* ==========================================================================
   MEGA MENU. Hide Collection Images — Text-Only for Compactness
   ========================================================================== */

/* Hide collection images and their placeholders entirely */
.mega-menu__link-image,
.mega-menu__grid:has(.mega-menu__link-image)
    .mega-menu__column
    > div
    > .mega-menu__link:not(:has(.mega-menu__link-image))::before {
    display: none !important;
}

/* Tighter padding inside the submenu panel */
.menu-list__list-item[data-category] .menu-list__submenu-inner {
    padding-top: var(--padding-lg, 1.25rem) !important;
    padding-bottom: var(--padding-lg, 1.25rem) !important;
}

/* Reduce gap between mega menu grid items */
.menu-list__list-item[data-category] .mega-menu__grid {
    gap: var(--padding-xs, 0.25rem) var(--padding-sm, 0.5rem) !important;
}

/* Compact the submenu max-height */
.menu-list__submenu-inner {
    max-height: calc(70vh - var(--header-height)) !important;
}

/* Fix vertical misalignment caused by image-mode padding on hidden images */
.mega-menu__link:has(.mega-menu__link-image),
.mega-menu__grid:has(.mega-menu__link-image)
    .mega-menu__column
    > div
    > .mega-menu__link:not(:has(.mega-menu__link-image)) {
    padding-block: 0 !important;
}

/* Hide collection images in mobile drawer menu */
@media screen and (max-width: 749px) {
    .menu-drawer__link-image {
        display: none !important;
    }

    .menu-drawer__menu--grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 0 !important;
    }

    .menu-drawer__menu-item:has(> .menu-drawer__link-image) {
        flex-direction: row !important;
        padding: var(--padding-sm) 0 !important;
    }
}

/* ==========================================================================
   PRODUCT CONDITION BADGES
   Displays New / Used / Open Box / Refurbished / Like New on cards + PDP.
   Uses product.metafields.custom.condition or "condition:<value>" tags.
   ========================================================================== */

/* ---------- Shared ---------- */

.product-condition {
    font-family: "Press Start 2P", monospace;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    line-height: 1;
}

/* ---------- Card badge (overlay on product image, top-right) ---------- */

.product-condition--card {
    position: absolute;
    z-index: var(--layer-flat, 1);
    top: calc(var(--badge-inset, 6px) + var(--padding-block-start, 0px));
    right: calc(var(--badge-inset, 6px) + var(--padding-inline-end, 0px));
    font-size: 8px;
    padding: 5px 9px;
    border-radius: 3px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    pointer-events: none;
}

/* ---------- PDP badge (inline, above the blocks) ---------- */

.product-condition--pdp {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 9px;
    padding: 8px 14px;
    border-radius: 4px;
    width: fit-content;
    margin-block-end: 4px;
}

.product-condition__icon {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.product-condition__label {
    opacity: 0.7;
    font-family: var(--font-body--family, sans-serif);
    font-size: 11px;
    text-transform: none;
    letter-spacing: normal;
}

.product-condition__value {
    font-weight: 700;
}

/* ---------- Color variants ---------- */

/* NEW — green terminal glow */
.condition--new {
    background: rgb(10 20 10 / 0.85);
    color: #39ff14;
    border: 1px solid rgb(57 255 20 / 0.5);
    box-shadow: 0 0 8px rgb(57 255 20 / 0.3);
}

/* USED — amber CRT warmth */
.condition--used {
    background: rgb(25 18 5 / 0.85);
    color: #ffbf00;
    border: 1px solid rgb(255 191 0 / 0.5);
    box-shadow: 0 0 8px rgb(255 191 0 / 0.25);
}

/* OPEN BOX — cyan/teal data stream */
.condition--open-box {
    background: rgb(5 18 20 / 0.85);
    color: #00e5ff;
    border: 1px solid rgb(0 229 255 / 0.5);
    box-shadow: 0 0 8px rgb(0 229 255 / 0.25);
}

/* REFURBISHED — purple synthwave */
.condition--refurbished {
    background: rgb(15 10 22 / 0.85);
    color: #bb86fc;
    border: 1px solid rgb(187 134 252 / 0.5);
    box-shadow: 0 0 8px rgb(187 134 252 / 0.25);
}

/* LIKE NEW — bright green, slightly different from New */
.condition--like-new {
    background: rgb(12 20 5 / 0.85);
    color: #76ff03;
    border: 1px solid rgb(118 255 3 / 0.5);
    box-shadow: 0 0 8px rgb(118 255 3 / 0.25);
}

/* ---------- PDP-specific enhancements ---------- */

.product-condition--pdp.condition--new {
    background:
        repeating-linear-gradient(0deg, transparent, transparent 2px, rgb(57 255 20 / 0.04) 2px, rgb(57 255 20 / 0.04) 3px),
        rgb(57 255 20 / 0.08);
}

.product-condition--pdp.condition--used {
    background:
        repeating-linear-gradient(0deg, transparent, transparent 2px, rgb(255 191 0 / 0.04) 2px, rgb(255 191 0 / 0.04) 3px),
        rgb(255 191 0 / 0.08);
}

.product-condition--pdp.condition--open-box {
    background:
        repeating-linear-gradient(0deg, transparent, transparent 2px, rgb(0 229 255 / 0.04) 2px, rgb(0 229 255 / 0.04) 3px),
        rgb(0 229 255 / 0.08);
}

.product-condition--pdp.condition--refurbished {
    background:
        repeating-linear-gradient(0deg, transparent, transparent 2px, rgb(187 134 252 / 0.04) 2px, rgb(187 134 252 / 0.04) 3px),
        rgb(187 134 252 / 0.08);
}

.product-condition--pdp.condition--like-new {
    background:
        repeating-linear-gradient(0deg, transparent, transparent 2px, rgb(118 255 3 / 0.04) 2px, rgb(118 255 3 / 0.04) 3px),
        rgb(118 255 3 / 0.08);
}

/* ---------- Mobile adjustments ---------- */

@media screen and (max-width: 749px) {
    .product-condition--card {
        font-size: 7px;
        padding: 4px 7px;
    }

    .product-condition--pdp {
        font-size: 8px;
        padding: 6px 10px;
    }

    .product-condition__label {
        font-size: 10px;
    }
}

/* ==========================================================================
   PRODUCT PAGE (PDP) — Full Geeky Overhaul
   ========================================================================== */

/* --------------------------------------------------------------------------
   PDP-1. Description — Fix flexed bullets / tables
   The .text-block parent uses display:flex which breaks table/list layout.
   Reset those elements to natural block/table display.
   -------------------------------------------------------------------------- */

.product-details .text-block table {
    display: table !important;
    width: 100% !important;
    border-collapse: collapse;
}

.product-details .text-block thead {
    display: table-header-group !important;
}

.product-details .text-block tbody {
    display: table-row-group !important;
}

.product-details .text-block tr {
    display: table-row !important;
}

.product-details .text-block th,
.product-details .text-block td {
    display: table-cell !important;
    text-align: start;
    padding: 8px 12px;
    border-bottom: 1px solid rgb(var(--color-foreground-rgb) / 0.1);
    vertical-align: top;
    font-size: 0.9rem;
}

.product-details .text-block th {
    font-weight: 600;
    white-space: nowrap;
    opacity: 0.7;
    width: 1%;
}

.product-details .text-block ul,
.product-details .text-block ol {
    display: block !important;
    padding-inline-start: 1.4em;
    margin-block: 0.5em;
    width: 100%;
}

.product-details .text-block li {
    display: list-item !important;
    margin-block-end: 0.35em;
    line-height: 1.6;
}

.product-details .text-block ul {
    list-style-type: disc;
}

.product-details .text-block ol {
    list-style-type: decimal;
}

/* --------------------------------------------------------------------------
   PDP-2. Product Title — Orbitron + Glow
   -------------------------------------------------------------------------- */

.product-details .text-block h1,
.product-details .text-block h2,
.product-details .text-block h3 {
    font-family: "Orbitron", sans-serif !important;
    font-weight: 700 !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
    text-shadow:
        0 0 10px rgb(var(--color-primary-rgb) / 0.15),
        0 0 30px rgb(var(--color-primary-rgb) / 0.05);
}

/* --------------------------------------------------------------------------
   PDP-3. Price — Bigger, bolder, accent glow
   -------------------------------------------------------------------------- */

.product-details product-price .price__current,
.product-details product-price .money {
    font-family: "Orbitron", sans-serif !important;
    font-weight: 900 !important;
    font-size: 1.8rem !important;
    color: #ffffff !important;
    text-shadow: none;
}

.product-details product-price .compare-at-price .money {
    font-family: "Orbitron", sans-serif !important;
    font-weight: 400 !important;
    font-size: 1.1rem !important;
    opacity: 0.45;
    color: var(--color-foreground) !important;
    text-shadow: none;
    text-decoration: line-through;
}

/* --------------------------------------------------------------------------
   PDP-4. Divider — Retro gradient line
   -------------------------------------------------------------------------- */

.product-details .divider {
    background: linear-gradient(
        90deg,
        transparent,
        rgb(var(--color-primary-rgb) / 0.4) 20%,
        rgb(var(--color-primary-rgb) / 0.6) 50%,
        rgb(var(--color-primary-rgb) / 0.4) 80%,
        transparent
    ) !important;
    height: 1px !important;
    border: none !important;
    box-shadow: 0 0 6px rgb(var(--color-primary-rgb) / 0.15);
}

/* --------------------------------------------------------------------------
   PDP-5. Variant Picker — Pixel-style buttons
   -------------------------------------------------------------------------- */

.product-details .variant-picker__option-value {
    font-family: "Orbitron", sans-serif !important;
    font-size: 0.75rem !important;
    letter-spacing: 0.03em !important;
    border-radius: 4px !important;
    border: 1px solid rgb(var(--color-foreground-rgb) / 0.2) !important;
    transition: all 0.2s ease !important;
}

.product-details .variant-picker__option-value:hover {
    border-color: rgb(var(--color-primary-rgb) / 0.5) !important;
    box-shadow: 0 0 8px rgb(var(--color-primary-rgb) / 0.15) !important;
}

.product-details .variant-picker__option-value[aria-checked="true"],
.product-details .variant-picker__option-value.is-selected {
    border-color: var(--color-primary) !important;
    box-shadow:
        0 0 8px rgb(var(--color-primary-rgb) / 0.25),
        inset 0 0 0 1px var(--color-primary) !important;
    color: var(--color-primary) !important;
}

.product-details .variant-picker__option-label {
    font-family: "Orbitron", sans-serif !important;
    font-size: 0.7rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    opacity: 0.8;
}

/* --------------------------------------------------------------------------
   PDP-6. Buy Buttons — Retro Geeky Treatment
   -------------------------------------------------------------------------- */

/* --- Add to Loot Bag (primary CTA) --- */

.product-details .add-to-cart-button.button {
    font-family: "Press Start 2P", monospace !important;
    font-size: 11px !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    border-radius: 4px !important;
    border: 1px solid rgb(202 64 15 / 0.6) !important;
    background:
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 2px,
            rgb(0 0 0 / 0.06) 2px,
            rgb(0 0 0 / 0.06) 3px
        ),
        #ca400f !important;
    color: #ffffff !important;
    box-shadow:
        0 0 12px rgb(202 64 15 / 0.3),
        inset 0 1px 0 rgb(255 255 255 / 0.1) !important;
    transition: all 0.2s ease !important;
}

.product-details .add-to-cart-button.button:hover:not(:disabled) {
    background:
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 2px,
            rgb(0 0 0 / 0.08) 2px,
            rgb(0 0 0 / 0.08) 3px
        ),
        #b03a0d !important;
    box-shadow:
        0 0 18px rgb(202 64 15 / 0.45),
        0 0 40px rgb(202 64 15 / 0.15),
        inset 0 1px 0 rgb(255 255 255 / 0.12) !important;
    transform: translateY(-1px);
}

/* --- Add to Loot Bag (secondary style, if used) --- */

.product-details .add-to-cart-button.button-secondary {
    font-family: "Press Start 2P", monospace !important;
    font-size: 11px !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    border-radius: 4px !important;
    border: 1px solid rgb(202 64 15 / 0.5) !important;
    background: rgb(202 64 15 / 0.08) !important;
    color: #ca400f !important;
    box-shadow: 0 0 8px rgb(202 64 15 / 0.15) !important;
    transition: all 0.2s ease !important;
}

.product-details .add-to-cart-button.button-secondary:hover:not(:disabled) {
    background: #ca400f !important;
    color: #ffffff !important;
    box-shadow:
        0 0 14px rgb(202 64 15 / 0.35),
        inset 0 1px 0 rgb(255 255 255 / 0.1) !important;
    transform: translateY(-1px);
}

/* --- Buy it now (Shopify accelerated checkout) --- */

.product-details .shopify-payment-button .shopify-payment-button__button {
    font-family: "Orbitron", sans-serif !important;
    font-size: 12px !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
    border-radius: 4px !important;
    border: 1px solid rgb(var(--color-foreground-rgb) / 0.15) !important;
    background:
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 2px,
            rgb(255 255 255 / 0.03) 2px,
            rgb(255 255 255 / 0.03) 3px
        ),
        rgb(var(--color-foreground-rgb) / 0.08) !important;
    color: var(--color-foreground) !important;
    box-shadow: 0 0 6px rgb(var(--color-foreground-rgb) / 0.08) !important;
    transition: all 0.2s ease !important;
}

.product-details .shopify-payment-button .shopify-payment-button__button:hover {
    background:
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 2px,
            rgb(255 255 255 / 0.04) 2px,
            rgb(255 255 255 / 0.04) 3px
        ),
        rgb(var(--color-foreground-rgb) / 0.14) !important;
    box-shadow: 0 0 10px rgb(var(--color-foreground-rgb) / 0.12) !important;
    transform: translateY(-1px);
}

/* --- Make an Offer (app uses <make-an-offer-button> with .ma-make-an-offer) --- */

make-an-offer-button #ma-make-an-offer-open-button,
.ma-make-an-offer-button button,
.product-details make-an-offer-button button,
.product-information make-an-offer-button button {
    font-family: "Press Start 2P", monospace !important;
    font-size: 10px !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
    border-radius: 4px !important;
    border: 1px solid rgb(0 229 255 / 0.5) !important;
    background:
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 2px,
            rgb(0 229 255 / 0.04) 2px,
            rgb(0 229 255 / 0.04) 3px
        ),
        rgb(0 229 255 / 0.1) !important;
    color: #00e5ff !important;
    box-shadow: 0 0 10px rgb(0 229 255 / 0.2) !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
    width: 100% !important;
}

make-an-offer-button #ma-make-an-offer-open-button:hover,
.ma-make-an-offer-button button:hover,
.product-details make-an-offer-button button:hover,
.product-information make-an-offer-button button:hover {
    background:
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 2px,
            rgb(0 0 0 / 0.08) 2px,
            rgb(0 0 0 / 0.08) 3px
        ),
        #00e5ff !important;
    color: #0d0d1a !important;
    box-shadow:
        0 0 18px rgb(0 229 255 / 0.45),
        0 0 40px rgb(0 229 255 / 0.15) !important;
    transform: translateY(-1px);
}

/* --- Quantity selector --- */

.product-details .quantity-selector {
    border-radius: 4px !important;
    border: 1px solid rgb(var(--color-foreground-rgb) / 0.15) !important;
}

.product-details .quantity-selector button {
    font-family: "Orbitron", sans-serif !important;
}

/* --------------------------------------------------------------------------
   PDP-7. Description Area — Full width + Retro card
   -------------------------------------------------------------------------- */

.product-details .text-block {
    width: 100% !important;
    max-width: 100% !important;
    --width: 100% !important;
}

.product-details .text-block > * {
    max-inline-size: 100% !important;
    width: 100% !important;
}

.product-details > .group-block > .group-block-content > .text-block:last-child {
    background: rgb(var(--color-foreground-rgb) / 0.04);
    border: 1px solid rgb(var(--color-foreground-rgb) / 0.1);
    border-radius: 6px;
    padding: 20px 24px !important;
    margin-block-start: 8px;
}

/* --------------------------------------------------------------------------
   PDP-8. Media Gallery — Ensure visibility + subtle enhancements
   -------------------------------------------------------------------------- */

.product-information__media {
    min-height: 200px;
}

/* Fix: flex-basis: 0% + aspect-ratio + min-width: 0 collapses width in grid view */
.media-gallery--grid .media-gallery__grid .product-media {
    flex-basis: auto !important;
    width: 100%;
}

.product-information__media .product-media__image {
    border-radius: 4px;
}

/* Carousel hover glow */
.product-information__media .product-media-container:hover {
    box-shadow: 0 0 12px rgb(var(--color-primary-rgb) / 0.12);
}

/* Zoom dialog — always-visible close button */
.dialog-zoomed-gallery__close-button {
    mix-blend-mode: normal !important;
    background: rgb(0 0 0 / 0.6) !important;
    color: #fff !important;
    border-radius: 50% !important;
    width: 44px !important;
    height: 44px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: fixed !important;
    top: 16px !important;
    right: 16px !important;
    z-index: 9999 !important;
    backdrop-filter: blur(8px);
    border: 1px solid rgb(255 255 255 / 0.15) !important;
    transition: background 0.2s ease, transform 0.2s ease !important;
}

.dialog-zoomed-gallery__close-button:hover {
    background: rgb(0 0 0 / 0.85) !important;
    transform: scale(1.1);
}

.dialog-zoomed-gallery__close-button svg {
    width: 18px !important;
    height: 18px !important;
}

/* Zoom dialog — thumbnail strip styling */
.dialog-thumbnails-list-container {
    background: rgb(0 0 0 / 0.5);
    backdrop-filter: blur(12px);
    padding: 8px;
}

.dialog-thumbnails-list__thumbnail {
    border-radius: 4px;
    overflow: hidden;
    border: 2px solid transparent;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.dialog-thumbnails-list__thumbnail[aria-selected="true"] {
    border-color: var(--color-primary, #ca400f);
    box-shadow: 0 0 8px rgb(var(--color-primary-rgb) / 0.3);
}

/* Zoom dialog — dark background */
.dialog-zoomed-gallery__dialog {
    background-color: rgb(10 10 10 / 0.95) !important;
}

/* --------------------------------------------------------------------------
   PDP-9. "You May Also Like" — Fix GRAB too close to title
   -------------------------------------------------------------------------- */

.product-recommendations .product-card__content.product-grid__card {
    padding-bottom: 70px !important;
}

.product-recommendations .resource-list__item .product-card {
    margin-block-end: 8px;
}

/* --------------------------------------------------------------------------
   PDP-10. Sticky Add-to-Cart Bar — Full geeky treatment
   -------------------------------------------------------------------------- */

.sticky-add-to-cart__bar {
    border: 1px solid rgb(202 64 15 / 0.25) !important;
    box-shadow:
        0 4px 24px rgb(0 0 0 / 0.5),
        0 0 12px rgb(202 64 15 / 0.1),
        inset 0 1px 0 rgb(255 255 255 / 0.04) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
}

.sticky-add-to-cart__button.add-to-cart-button.button {
    font-family: "Press Start 2P", monospace !important;
    font-size: 9px !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
    border-radius: 4px !important;
    background:
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 2px,
            rgb(0 0 0 / 0.06) 2px,
            rgb(0 0 0 / 0.06) 3px
        ),
        #ca400f !important;
    color: #ffffff !important;
    border: 1px solid rgb(202 64 15 / 0.5) !important;
    box-shadow: 0 0 10px rgb(202 64 15 / 0.3) !important;
    transition: all 0.2s ease !important;
}

.sticky-add-to-cart__button.add-to-cart-button.button:hover:not(:disabled) {
    background:
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 2px,
            rgb(0 0 0 / 0.08) 2px,
            rgb(0 0 0 / 0.08) 3px
        ),
        #b03a0d !important;
    box-shadow:
        0 0 16px rgb(202 64 15 / 0.45),
        0 0 36px rgb(202 64 15 / 0.12) !important;
    transform: translateY(-1px);
}

.sticky-add-to-cart__title {
    font-family: "Orbitron", sans-serif !important;
    font-weight: 600 !important;
    letter-spacing: 0.03em !important;
}

.sticky-add-to-cart__price .money {
    font-family: "Orbitron", sans-serif !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    text-shadow: none;
}

/* --------------------------------------------------------------------------
   PDP-11. Mobile adjustments
   -------------------------------------------------------------------------- */

@media screen and (max-width: 749px) {
    .product-details .add-to-cart-button.button,
    .product-details .add-to-cart-button.button-secondary {
        font-size: 9px !important;
        padding: 14px 16px !important;
    }

    .product-details .shopify-payment-button .shopify-payment-button__button {
        font-size: 10px !important;
    }

    make-an-offer-button #ma-make-an-offer-open-button,
    .ma-make-an-offer-button button,
    .product-details make-an-offer-button button,
    .product-information make-an-offer-button button {
        font-size: 8px !important;
        padding: 14px 16px !important;
    }

    .product-details > .group-block > .group-block-content > .text-block:last-child {
        padding: 14px 16px !important;
    }

    .product-details .text-block th,
    .product-details .text-block td {
        padding: 6px 8px;
        font-size: 0.82rem;
    }

    .product-details product-price .money {
        font-size: 1.4rem !important;
    }

    .sticky-add-to-cart__button.add-to-cart-button.button {
        font-size: 8px !important;
    }
}

/* --------------------------------------------------------------------------
   COMING SOON — Collection placeholder for collections without images
   -------------------------------------------------------------------------- */

.geekz-coming-soon-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    min-height: 200px;
    aspect-ratio: 1;
    background:
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 3px,
            rgb(255 255 255 / 0.02) 3px,
            rgb(255 255 255 / 0.02) 4px
        ),
        linear-gradient(135deg, #1a1a1a 0%, #0d0d0d 100%);
    border: 1px solid rgb(255 255 255 / 0.08);
    border-radius: 4px;
}

.geekz-coming-soon-placeholder__icon {
    font-size: 2.5rem;
    margin-bottom: 12px;
    opacity: 0.7;
}

.geekz-coming-soon-placeholder__text {
    font-family: "Press Start 2P", monospace;
    font-size: 11px;
    letter-spacing: 0.15em;
    color: rgb(255 255 255 / 0.5);
    text-transform: uppercase;
}
