/* â”€â”€ P&aacute;gina pre-venta â”€â”€ */
        .pv-page {
            min-height: 100vh;
            display: flex;
            flex-direction: column;
        }
        .pv-topbar {
            background: rgba(5,5,5,0.95);
            backdrop-filter: blur(12px);
            -webkit-backdrop-filter: blur(12px);
            border-bottom: 1px solid var(--glass-border);
            padding: 14px 24px;
            display: flex;
            align-items: center;
            justify-content: space-between;
            position: sticky;
            top: 0;
            z-index: 100;
        }
        .pv-topbar > * { min-width: 0; }
        .pv-back {
            display: flex;
            align-items: center;
            gap: 8px;
            color: var(--text-secondary);
            text-decoration: none;
            font-size: 0.82rem;
            font-weight: 600;
            letter-spacing: 0.5px;
            transition: color 0.2s;
        }
        .pv-back:hover { color: var(--gold); }
        .pv-topbar-logo {
            height: 42px;
            object-fit: contain;
        }
        .pv-topbar-right {
            width: 80px; /* balance visual */
        }

        /* Hero banner */
        .pv-hero {
            background: linear-gradient(135deg, #0a0a0a 0%, #1a1710 50%, #0a0a08 100%);
            padding: 60px 20px 50px;
            text-align: center;
            position: relative;
            overflow: hidden;
        }
        .pv-hero::before {
            content: '';
            position: absolute;
            top: -60px; left: 50%;
            transform: translateX(-50%);
            width: 600px; height: 300px;
            background: radial-gradient(ellipse, rgba(217,195,145,0.08) 0%, transparent 70%);
            pointer-events: none;
        }
        .pv-badge {
            display: inline-block;
            background: var(--gold);
            color: #111;
            font-size: 0.68rem;
            font-weight: 800;
            letter-spacing: 3px;
            padding: 5px 18px;
            border-radius: 20px;
            text-transform: uppercase;
            margin-bottom: 18px;
        }
        .pv-title {
            font-family: 'Oswald', sans-serif;
            font-size: clamp(2.4rem, 7vw, 4rem);
            text-transform: uppercase;
            color: #fff;
            line-height: 1.05;
            margin-bottom: 10px;
        }
        .pv-title span { color: var(--gold); font-style: italic; }
        .pv-subtitle {
            color: var(--text-secondary);
            font-size: 1rem;
            max-width: 520px;
            margin: 0 auto 16px;
            line-height: 1.75;
        }
        .pv-subtitle strong { color: #fff; }
        .pv-personaliz-tag {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            background: rgba(217,195,145,0.1);
            border: 1px solid rgba(217,195,145,0.3);
            color: var(--gold);
            padding: 6px 16px;
            border-radius: 20px;
            font-size: 0.8rem;
            font-weight: 700;
            letter-spacing: 0.5px;
            margin-bottom: 36px;
        }

        /* Info cards */
        .pv-cards {
            display: flex;
            gap: 12px;
            justify-content: center;
            flex-wrap: wrap;
            max-width: 700px;
            margin: 0 auto;
        }
        .pv-card {
            background: rgba(217,195,145,0.05);
            border: 1px solid var(--glass-border);
            border-radius: 14px;
            padding: 16px 18px;
            text-align: center;
            flex: 1;
            min-width: 100px;
            max-width: 145px;
        }
        .pv-card-icon { font-size: 1.4rem; display: block; margin-bottom: 6px; }
        .pv-card-label {
            font-size: 0.6rem;
            color: var(--text-secondary);
            text-transform: uppercase;
            letter-spacing: 1px;
            margin-bottom: 3px;
        }
        .pv-card-val {
            font-size: 0.88rem;
            font-weight: 700;
            color: var(--gold);
            font-family: 'Oswald', sans-serif;
        }

        /* Wizard */
        .pv-wizard-wrap {
            flex: 1;
            padding: 40px 20px 60px;
            display: flex;
            flex-direction: column;
            align-items: center;
        }
        .pv-wizard {
            width: 100%;
            max-width: 580px;
            background: rgba(12,12,12,0.95);
            backdrop-filter: blur(24px);
            -webkit-backdrop-filter: blur(24px);
            border: 1px solid var(--glass-border);
            border-radius: 20px;
            overflow: hidden;
        }
        .pv-progress {
            display: flex;
            align-items: flex-start;
            padding: 20px 24px 16px;
            border-bottom: 1px solid rgba(255,255,255,0.06);
        }
        .pv-body { padding: 26px; }
        .pv-nav {
            padding: 0 24px 22px;
            display: flex;
            gap: 10px;
        }
        .pv-step-title {
            font-family: 'Oswald', sans-serif;
            font-size: 1.2rem;
            text-transform: uppercase;
            color: #fff;
            margin-bottom: 3px;
        }
        .pv-step-sub {
            font-size: 0.79rem;
            color: var(--text-secondary);
            margin-bottom: 20px;
        }
        .pv-label {
            display: block;
            font-size: 0.7rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 1px;
            color: var(--text-secondary);
            margin-bottom: 6px;
        }
        .pv-input, .pv-textarea {
            width: 100%;
            background: rgba(255,255,255,0.05);
            border: 1px solid rgba(255,255,255,0.1);
            border-radius: 8px;
            padding: 11px 14px;
            color: #fff;
            font-family: 'Montserrat', sans-serif;
            font-size: 0.88rem;
            outline: none;
            transition: border-color 0.2s;
        }
        .pv-input::placeholder, .pv-textarea::placeholder { color: rgba(255,255,255,0.2); }
        .pv-input:focus, .pv-textarea:focus { border-color: var(--gold); }
        .pv-textarea { resize: vertical; min-height: 68px; }
        .pv-group { margin-bottom: 14px; }
        .btn-pv-back {
            background: transparent;
            border: 1.5px solid rgba(255,255,255,0.15);
            color: var(--text-secondary);
            padding: 11px 20px;
            border-radius: 8px;
            cursor: pointer;
            font-size: 0.84rem;
            font-family: 'Montserrat', sans-serif;
            font-weight: 600;
            transition: all 0.2s;
        }
        .btn-pv-back:hover { border-color: rgba(255,255,255,0.4); color: #fff; }
        .btn-pv-next {
            flex: 1;
            background: var(--gold);
            border: none;
            color: #111;
            padding: 12px 24px;
            border-radius: 8px;
            cursor: pointer;
            font-size: 0.9rem;
            font-family: 'Oswald', sans-serif;
            font-weight: 700;
            letter-spacing: 1px;
            text-transform: uppercase;
            transition: all 0.2s;
        }
        .btn-pv-next:hover { background: var(--gold-hover); transform: translateY(-1px); }

        /* Mobile */
        @media (max-width: 767px) {
            html, body {
                max-width: 100%;
                overflow-x: hidden;
            }
            body {
                background-attachment: scroll !important;
            }
            .pv-topbar {
                padding: 12px 14px;
                gap: 10px;
            }
            .pv-back {
                font-size: 0.72rem;
                gap: 6px;
            }
            .pv-topbar-logo {
                height: 34px;
            }
            .pv-topbar-right {
                display: none;
            }
            .pv-hero { padding: 40px 16px 36px; }
            .pv-title {
                font-size: clamp(2rem, 11vw, 2.8rem);
            }
            .pv-subtitle {
                font-size: 0.92rem;
                line-height: 1.6;
            }
            .pv-cards {
                display: grid;
                grid-template-columns: repeat(2, minmax(0, 1fr));
                gap: 10px;
                max-width: 360px;
            }
            .pv-card {
                min-width: 0;
                max-width: none;
                padding: 14px 12px;
            }
            .pv-body { padding: 20px 16px; }
            .pv-nav {
                padding: 0 16px 18px;
                flex-direction: column-reverse;
            }
            .btn-pv-back,
            .btn-pv-next {
                width: 100%;
            }
            .pv-progress { padding: 16px 16px 12px; }
            body { padding-bottom: calc(var(--nav-h) + env(safe-area-inset-bottom, 0px)); }
        }

        /* ── Galería pre-venta ─────────────────────────────────────── */
        .pv-galeria {
            background: linear-gradient(180deg, rgba(10,8,4,0) 0%, rgba(10,8,4,0.6) 8%, rgba(10,8,4,0.6) 92%, rgba(10,8,4,0) 100%);
            padding: 28px 0 60px;
            position: relative;
            width: 100%;
            overflow-x: clip;
        }
        .pv-galeria-inner { max-width: 1300px; width: 100%; min-width: 0; margin: 0 auto; padding: 0 16px; }

        /* Header */
        .pv-galeria-header { text-align: center; margin-bottom: 20px; }
        .pv-galeria-eyebrow {
            display: inline-flex; align-items: center; gap: 10px;
            font-size: 0.65rem; font-weight: 800; letter-spacing: 4px;
            text-transform: uppercase; color: var(--gold); margin-bottom: 16px;
        }
        .pv-galeria-eyebrow::before, .pv-galeria-eyebrow::after {
            content: ''; display: block; width: 40px; height: 1px; background: var(--gold); opacity: 0.5;
        }
        .pv-galeria-title {
            font-family: 'Oswald', sans-serif;
            font-size: clamp(2.2rem, 6vw, 3.8rem);
            text-transform: uppercase;
            color: #fff;
            line-height: 1.0;
            margin: 0 0 12px;
            letter-spacing: -0.5px;
            overflow-wrap: anywhere;
        }
        .pv-galeria-title span { color: var(--gold); font-style: italic; }
        .pv-galeria-sub { color: rgba(255,255,255,0.45); font-size: 0.9rem; margin: 0; }

        /* Buscador */
        .pv-search-wrap {
            display: flex; justify-content: center; margin-bottom: 20px; width: 100%; min-width: 0;
        }
        .pv-search {
            width: 100%; max-width: 420px;
            padding: 12px 20px 12px 44px;
            border-radius: 30px;
            border: 1px solid var(--glass-border);
            background: rgba(255,255,255,0.05);
            color: var(--text-primary);
            font-family: 'Montserrat', sans-serif;
            font-size: 0.88rem;
            outline: none;
            backdrop-filter: blur(4px);
            transition: all 0.3s ease;
        }
        .pv-search::placeholder { color: rgba(255,255,255,0.35); }
        .pv-search:focus {
            border-color: var(--gold);
            background: rgba(255,255,255,0.1);
            box-shadow: 0 0 15px rgba(217,195,145,0.2);
        }
        .pv-search-icon {
            position: absolute; left: 16px; top: 50%; transform: translateY(-50%);
            color: rgba(255,255,255,0.3); font-size: 1.1rem; pointer-events: none;
        }
        .pv-search-container {
            position: relative; width: 100%; max-width: 420px; min-width: 0;
        }

        /* Filtros */
        .pv-filtros {
            display: flex; flex-wrap: wrap; gap: 8px;
            justify-content: center; margin-bottom: 20px;
        }
        .pv-filtro-btn {
            background: rgba(255,255,255,0.04);
            border: 1px solid rgba(255,255,255,0.1);
            color: rgba(255,255,255,0.5);
            padding: 8px 20px; border-radius: 24px;
            font-size: 0.72rem; font-weight: 700; letter-spacing: 1px;
            text-transform: uppercase; cursor: pointer;
            transition: all 0.18s; font-family: 'Montserrat', sans-serif;
        }
        .pv-filtro-btn:hover { border-color: rgba(217,195,145,0.5); color: var(--gold); background: rgba(217,195,145,0.05); }
        .pv-filtro-btn.active { background: var(--gold); border-color: var(--gold); color: #111; }

        .pv-gallery-shell {
            display: grid;
            gap: 24px;
            width: 100%;
            min-width: 0;
        }
        .pv-intro-copy {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 18px;
            padding: 18px 22px;
            border: 1px solid rgba(217,195,145,0.14);
            border-radius: 18px;
            background:
                linear-gradient(135deg, rgba(217,195,145,0.12) 0%, rgba(217,195,145,0.04) 30%, rgba(255,255,255,0.02) 100%);
            box-shadow: 0 20px 60px rgba(0,0,0,0.18);
            width: 100%;
            min-width: 0;
        }
        .pv-intro-copy p {
            margin: 0;
            max-width: 720px;
            color: rgba(255,255,255,0.62);
            font-size: 0.9rem;
            line-height: 1.7;
            min-width: 0;
            overflow-wrap: anywhere;
        }
        .pv-intro-chip {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            padding: 10px 14px;
            border-radius: 999px;
            background: rgba(8,8,8,0.55);
            border: 1px solid rgba(217,195,145,0.22);
            color: var(--gold);
            font-size: 0.72rem;
            font-weight: 800;
            letter-spacing: 1.2px;
            text-transform: uppercase;
            flex-shrink: 0;
        }
        .pv-grid-stage {
            display: grid;
            gap: 28px;
            width: 100%;
            min-width: 0;
        }
        .mobile-bottom-nav .mobile-nav-btn.is-current {
            color: var(--gold);
            background: rgba(217,195,145,0.12);
        }
        .mobile-bottom-nav .mobile-nav-btn.is-current svg {
            filter: drop-shadow(0 0 8px rgba(217,195,145,0.18));
        }
        .mobile-bottom-nav .mobile-nav-btn.is-active {
            color: var(--gold);
        }
        .pv-section {
            content-visibility: auto;
            contain-intrinsic-size: 900px;
            background: rgba(255,255,255,0.02);
            border: 1px solid rgba(255,255,255,0.06);
            border-radius: 24px;
            padding: 24px;
            box-shadow: 0 24px 70px rgba(0,0,0,0.16);
            width: 100%;
            min-width: 0;
        }
        .pv-section-featured {
            background:
                radial-gradient(circle at top left, rgba(217,195,145,0.12), transparent 40%),
                linear-gradient(145deg, rgba(18,16,12,0.98), rgba(8,8,8,0.96));
            border-color: rgba(217,195,145,0.18);
        }
        .pv-section-head {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 16px;
            margin-bottom: 14px;
            width: 100%;
            min-width: 0;
        }
        .pv-section-head > div:first-child { min-width: 0; }
        .pv-section-kicker {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            color: var(--gold);
            font-size: 0.7rem;
            font-weight: 800;
            letter-spacing: 1.4px;
            text-transform: uppercase;
            margin-bottom: 8px;
        }
        .pv-section-title {
            margin: 0;
            color: #fff;
            font-family: 'Oswald', sans-serif;
            font-size: clamp(1.5rem, 3vw, 2.2rem);
            line-height: 1;
            text-transform: uppercase;
        }
        .pv-section-sub {
            display: none;
        }
        .pv-section-meta {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            padding: 8px 12px;
            border-radius: 999px;
            background: rgba(255,255,255,0.04);
            border: 1px solid rgba(255,255,255,0.08);
            color: rgba(255,255,255,0.62);
            font-size: 0.74rem;
            font-weight: 700;
            letter-spacing: 0.8px;
            text-transform: uppercase;
            white-space: nowrap;
        }
        .pv-section-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 24px;
        }
        .pv-section-grid.pv-section-grid-featured {
            gap: 28px;
        }
        .pv-section-actions {
            display: flex;
            justify-content: center;
            margin-top: 20px;
        }
        .pv-more-btn {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            border: 1px solid rgba(217,195,145,0.24);
            background: rgba(217,195,145,0.06);
            color: var(--gold);
            border-radius: 999px;
            padding: 11px 18px;
            font-family: 'Montserrat', sans-serif;
            font-size: 0.76rem;
            font-weight: 800;
            letter-spacing: 1px;
            text-transform: uppercase;
            cursor: pointer;
            transition: all 0.2s ease;
        }
        .pv-more-btn:hover {
            background: rgba(217,195,145,0.13);
            transform: translateY(-2px);
        }

        /* Grid — 3 columnas en desktop como el catálogo */
        .pv-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 30px;
            width: 100%;
            min-width: 0;
        }

        /* Card — diseño igual al catálogo principal */
        .pv-card-item {
            background: var(--card-bg);
            backdrop-filter: blur(10px);
            -webkit-backdrop-filter: blur(10px);
            border-radius: 16px;
            overflow: hidden;
            border: 1px solid var(--glass-border);
            transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
            cursor: pointer;
            box-shadow: 0 8px 32px 0 rgba(0,0,0,0.3);
            display: flex;
            flex-direction: column;
            color: inherit;
            text-decoration: none;
        }
        .pv-card-item:hover {
            transform: translateY(-8px);
            border-color: var(--gold);
            box-shadow: 0 15px 45px rgba(217,195,145,0.15);
        }

        /* Foto principal */
        .pv-card-img-wrap {
            position: relative;
            width: 100%;
            aspect-ratio: 4/5;
            background: radial-gradient(circle at center, rgba(30,30,30,0.8) 0%, transparent 100%);
            overflow: hidden;
        }
        /* Shimmer animation on hover — like main catalog */
        .pv-card-img-wrap::before {
            content: '';
            position: absolute;
            top: 0; left: -100%; width: 50%; height: 100%;
            background: linear-gradient(to right, transparent, rgba(255,255,255,0.05), transparent);
            transform: skewX(-20deg);
            transition: 0.5s;
            z-index: 2;
        }
        .pv-card-item:hover .pv-card-img-wrap::before { left: 150%; }

        .pv-card-img-wrap img {
            width: 100%; height: 100%;
            object-fit: cover;
            transition: transform 0.5s ease, opacity 0.4s ease;
            position: absolute; top: 0; left: 0;
        }
        .pv-card-item:hover .pv-card-img-wrap img.pv-img-main {
            transform: scale(1.06) rotate(-1deg);
            opacity: 0;
        }
        .pv-card-img-wrap img.pv-img-hover { opacity: 0; transform: scale(1.06); }
        .pv-card-item:hover .pv-card-img-wrap img.pv-img-hover { opacity: 1; transform: scale(1.0); }

        /* Info debajo de la foto — como catálogo principal */
        .pv-card-info {
            padding: 14px 16px 16px;
            display: flex;
            flex-direction: column;
            flex-grow: 1;
            background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.5) 100%);
        }
        .pv-card-equipo {
            font-size: 0.85rem; font-weight: 700; color: #fff;
            text-transform: uppercase; letter-spacing: 0.5px;
            line-height: 1.3; margin-bottom: 4px;
            display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
        }
        .pv-card-precio {
            font-size: 1.05rem; color: var(--gold); font-weight: 600;
            margin-bottom: 4px; letter-spacing: 0.5px;
            font-family: 'Oswald', sans-serif;
        }
        .pv-card-meta {
            font-size: 0.7rem; color: var(--text-secondary);
            text-transform: uppercase; letter-spacing: 0.5px;
            margin-bottom: 10px;
        }
        .pv-card-cta {
            display: flex; align-items: center; justify-content: center; gap: 8px;
            background: var(--gold); color: var(--bg-dark);
            padding: 10px 16px; border-radius: 20px;
            font-size: 0.75rem; font-weight: 700;
            letter-spacing: 1px; text-transform: uppercase;
            text-decoration: none;
            transition: all 0.3s ease;
            margin-top: auto;
        }
        .pv-card-cta:hover {
            background: var(--gold-hover);
            box-shadow: 0 0 15px rgba(217,195,145,0.3);
            transform: translateY(-2px);
        }

        /* Badges */
        .pv-dest-badge {
            position: absolute; top: 10px; left: 10px; z-index: 3;
            background: var(--gold); color: #111;
            font-size: 0.65rem; font-weight: 900; padding: 4px 10px; border-radius: 10px;
            letter-spacing: 0.5px;
        }
        .pv-leadtime-badge {
            position: absolute;
            left: 10px;
            bottom: 10px;
            z-index: 3;
            display: inline-flex;
            align-items: center;
            gap: 6px;
            background: rgba(8,8,8,0.72);
            backdrop-filter: blur(6px);
            border: 1px solid rgba(217,195,145,0.28);
            color: #fff;
            font-size: 0.62rem;
            font-weight: 800;
            padding: 5px 10px;
            border-radius: 999px;
            letter-spacing: 0.8px;
            text-transform: uppercase;
        }
        /* Indicador de fotos */
        .pv-photo-count {
            position: absolute; top: 10px; right: 10px; z-index: 3;
            background: rgba(0,0,0,0.55); backdrop-filter: blur(4px);
            border: 1px solid rgba(255,255,255,0.1);
            color: rgba(255,255,255,0.7);
            font-size: 0.65rem; font-weight: 700; letter-spacing: 0.5px;
            padding: 4px 10px; border-radius: 10px;
            display: flex; align-items: center; gap: 4px;
        }

        /* Skeleton loader */
        .pv-grid-loading { display: grid; grid-template-columns: repeat(3,1fr); gap: 30px; width:100%; }
        .pv-skeleton {
            border-radius: 16px; overflow: hidden;
        }
        .pv-skeleton-img {
            aspect-ratio: 4/5;
            background: linear-gradient(90deg, rgba(30,30,30,0.8) 25%, rgba(60,55,45,0.6) 50%, rgba(30,30,30,0.8) 75%);
            background-size: 600px 100%;
            animation: pvShimmer 1.6s infinite linear;
        }
        .pv-skeleton-info {
            padding: 14px 16px 16px;
            background: var(--card-bg);
        }
        .pv-skeleton-line {
            height: 12px; border-radius: 6px; margin-bottom: 8px;
            background: rgba(255,255,255,0.06);
        }
        .pv-skeleton-line.short { width: 60%; }
        .pv-skeleton-line.price { width: 40%; height: 16px; }
        @keyframes pvShimmer {
            0%   { background-position: -600px 0; }
            100% { background-position:  600px 0; }
        }

        @media (min-width: 768px) and (max-width: 1023px) {
            .pv-grid, .pv-grid-loading, .pv-section-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
        }
        @media (max-width: 767px) {
            .pv-galeria { padding: 16px 0 40px; }
            .pv-galeria-inner {
                padding: 0 12px;
            }
            .pv-galeria-header {
                margin-bottom: 14px;
                width: 100%;
                min-width: 0;
            }
            .pv-galeria-title {
                font-size: clamp(1.4rem, 7vw, 1.9rem);
                margin-bottom: 0;
            }
            .pv-galeria-sub {
                font-size: 0.82rem;
                line-height: 1.55;
                max-width: 290px;
                margin: 0 auto;
            }
            .pv-search-wrap {
                margin-bottom: 14px;
            }
            .pv-search {
                font-size: 16px;
                padding: 12px 16px 12px 42px;
            }
            .pv-search-container {
                max-width: none;
            }
            .pv-filtros {
                flex-wrap: nowrap;
                justify-content: flex-start;
                overflow-x: auto;
                -webkit-overflow-scrolling: touch;
                scrollbar-width: none;
                padding-bottom: 8px;
                margin-bottom: 12px;
                width: 100%;
            }
            .pv-filtros::-webkit-scrollbar {
                display: none;
            }
            .pv-filtro-btn {
                flex: 0 0 auto;
                white-space: nowrap;
                padding: 7px 12px;
                font-size: 0.68rem;
            }
            .pv-gallery-shell { gap: 14px; }
            .pv-intro-copy {
                flex-direction: column;
                align-items: flex-start;
                padding: 16px;
            }
            .pv-intro-copy p {
                font-size: 0.84rem;
                line-height: 1.6;
            }
            .pv-intro-chip {
                width: 100%;
                justify-content: center;
            }
            .pv-section {
                padding: 18px 14px;
                border-radius: 18px;
            }
            .pv-section-head {
                flex-direction: row;
                align-items: center;
                margin-bottom: 12px;
            }
            .pv-section-sub {
                display: none;
            }
            .pv-section-kicker {
                margin-bottom: 4px;
                font-size: 0.62rem;
            }
            .pv-section-title {
                font-size: clamp(1.1rem, 5vw, 1.5rem);
            }
            .pv-section-meta {
                font-size: 0.68rem;
                padding: 7px 10px;
                flex-shrink: 0;
            }
            .pv-grid, .pv-grid-loading, .pv-section-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
            .pv-card-item {
                border-radius: 18px;
            }
            .pv-card-equipo { font-size: 0.75rem; }
            .pv-card-precio { font-size: 0.9rem; }
            .pv-card-info { padding: 10px 12px 14px; }
            .pv-card-meta {
                font-size: 0.64rem;
                margin-bottom: 8px;
            }
            .pv-card-cta {
                padding: 9px 10px;
                font-size: 0.64rem;
                width: 100%;
            }
            .pv-dest-badge,
            .pv-photo-count,
            .pv-leadtime-badge {
                font-size: 0.56rem;
                padding: 4px 8px;
            }
        }

        @media (max-width: 560px) {
            .pv-back {
                max-width: 120px;
            }
            .pv-grid,
            .pv-grid-loading,
            .pv-section-grid {
                grid-template-columns: repeat(2, 1fr);
                gap: 12px;
            }
            body.pv-mobile-single .pv-grid,
            body.pv-mobile-single .pv-grid-loading,
            body.pv-mobile-single .pv-section-grid {
                grid-template-columns: 1fr;
                gap: 14px;
            }
            .pv-card-equipo {
                font-size: 0.86rem;
            }
            .pv-card-precio {
                font-size: 1rem;
            }
            .pv-card-meta {
                font-size: 0.68rem;
            }
            .pv-card-cta {
                font-size: 0.68rem;
            }
        }

        @media (hover: none) and (pointer: coarse) {
            .pv-card-item:hover {
                transform: none;
                border-color: var(--glass-border);
                box-shadow: 0 8px 32px 0 rgba(0,0,0,0.3);
            }
            .pv-card-item:hover .pv-card-img-wrap::before {
                left: -100%;
            }
            .pv-card-item:hover .pv-card-img-wrap img.pv-img-main {
                transform: none;
                opacity: 1;
            }
            .pv-card-img-wrap img.pv-img-hover {
                display: none;
            }
            .pv-card-item:hover .pv-card-cta {
                transform: none;
                box-shadow: none;
            }
        }

        /* ── Lightbox / Modal ─────────────────────────────────────── */
        .pv-lightbox {
            position: fixed; inset: 0; z-index: 9999;
            background: rgba(0,0,0,0.92);
            backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
            display: none; flex-direction: column;
            align-items: center; justify-content: center;
            opacity: 0; transition: opacity 0.3s ease;
        }
        .pv-lightbox.active { display: flex; opacity: 1; }
        .pv-lightbox.entering { display: flex; opacity: 0; }

        .pv-lb-close {
            position: absolute; top: 16px; right: 20px; z-index: 10;
            background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.15);
            color: #fff; width: 40px; height: 40px; border-radius: 50%;
            font-size: 1.3rem; cursor: pointer; display: flex;
            align-items: center; justify-content: center;
            transition: all 0.2s;
        }
        .pv-lb-close:hover { background: rgba(255,255,255,0.15); transform: scale(1.1); }

        .pv-lb-content {
            display: flex; flex-direction: column; align-items: center;
            max-width: 900px; width: 100%; padding: 0 20px;
            position: relative;
        }

        /* Carousel area */
        .pv-lb-carousel {
            position: relative; width: 100%;
            max-height: 70vh; display: flex;
            align-items: center; justify-content: center;
        }
        .pv-lb-img {
            max-width: 100%; max-height: 68vh;
            object-fit: contain; border-radius: 12px;
            box-shadow: 0 20px 60px rgba(0,0,0,0.6);
            transition: opacity 0.25s ease, transform 0.25s ease;
            user-select: none; -webkit-user-drag: none;
        }
        .pv-lb-img.switching {
            opacity: 0; transform: scale(0.96);
        }

        /* Arrows */
        .pv-lb-arrow {
            position: absolute; top: 50%; transform: translateY(-50%);
            background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.12);
            color: #fff; width: 44px; height: 44px; border-radius: 50%;
            font-size: 1.2rem; cursor: pointer; display: flex;
            align-items: center; justify-content: center;
            transition: all 0.2s; z-index: 5;
        }
        .pv-lb-arrow:hover { background: rgba(217,195,145,0.15); border-color: rgba(217,195,145,0.4); color: var(--gold); }
        .pv-lb-arrow.left { left: -56px; }
        .pv-lb-arrow.right { right: -56px; }

        /* Dots */
        .pv-lb-dots {
            display: flex; gap: 8px; justify-content: center;
            margin-top: 16px;
        }
        .pv-lb-dot {
            width: 8px; height: 8px; border-radius: 50%;
            background: rgba(255,255,255,0.2); border: none;
            cursor: pointer; transition: all 0.2s; padding: 0;
        }
        .pv-lb-dot.active { background: var(--gold); transform: scale(1.3); }

        /* Thumbnails strip */
        .pv-lb-thumbs {
            display: flex; gap: 8px; justify-content: center;
            margin-top: 14px; overflow-x: auto; max-width: 100%;
            padding: 4px 0;
        }
        .pv-lb-thumbs::-webkit-scrollbar { height: 3px; }
        .pv-lb-thumbs::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 4px; }
        .pv-lb-thumb {
            width: 52px; height: 68px; border-radius: 6px;
            object-fit: cover; cursor: pointer;
            border: 2px solid transparent;
            opacity: 0.5; transition: all 0.2s;
            flex-shrink: 0;
        }
        .pv-lb-thumb:hover { opacity: 0.8; }
        .pv-lb-thumb.active { border-color: var(--gold); opacity: 1; }

        /* Info bar */
        .pv-lb-info {
            display: flex; align-items: center; justify-content: space-between;
            gap: 16px; width: 100%; max-width: 600px;
            margin-top: 20px; flex-wrap: wrap;
        }
        .pv-lb-details { text-align: left; }
        .pv-lb-equipo {
            font-family: 'Oswald', sans-serif; font-size: 1.4rem;
            text-transform: uppercase; color: #fff; font-weight: 700;
            letter-spacing: 0.5px; line-height: 1.1;
        }
        .pv-lb-meta {
            font-size: 0.8rem; color: rgba(255,255,255,0.5);
            margin-top: 4px; text-transform: capitalize;
        }
        .pv-lb-precio {
            font-family: 'Oswald', sans-serif; font-size: 1.5rem;
            color: var(--gold); font-weight: 700;
        }
        .pv-lb-cta {
            display: inline-flex; align-items: center; gap: 8px;
            background: var(--gold); color: #111; border: none;
            padding: 12px 28px; border-radius: 10px;
            font-family: 'Oswald', sans-serif; font-size: 0.95rem;
            font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
            cursor: pointer; transition: all 0.2s;
        }
        .pv-lb-cta:hover { background: var(--gold-hover); transform: translateY(-2px); }

        .pv-lb-counter {
            position: absolute; top: 16px; left: 20px; z-index: 10;
            background: rgba(0,0,0,0.5); border: 1px solid rgba(255,255,255,0.1);
            color: rgba(255,255,255,0.7); font-size: 0.72rem; font-weight: 700;
            padding: 4px 12px; border-radius: 20px; letter-spacing: 1px;
        }

        @media (max-width: 900px) {
            .pv-lb-arrow.left { left: 8px; }
            .pv-lb-arrow.right { right: 8px; }
            .pv-lb-arrow { width: 36px; height: 36px; font-size: 1rem;
                background: rgba(0,0,0,0.5); }
        }
        @media (max-width: 520px) {
            .pv-lb-content {
                padding: 48px 12px 18px;
            }
            .pv-lb-carousel {
                min-height: 52vh;
            }
            .pv-lb-img {
                max-height: 52vh;
            }
            .pv-lb-equipo { font-size: 1.1rem; }
            .pv-lb-precio { font-size: 1.2rem; }
            .pv-lb-info { justify-content: center; text-align: center; }
            .pv-lb-details { text-align: center; }
            .pv-lb-cta { width: 100%; justify-content: center; padding: 14px; }
            .pv-lb-thumb { width: 42px; height: 56px; }
        }
