:root {
    --cdvip-gold: #c8a45c;
    --cdvip-gold-2: #b88c3a;
    --cdvip-gold-soft: rgba(200,164,92,.18);
    --cdvip-bg: #0c0c0c;
    --cdvip-bg-card: #141414;
    --cdvip-bg-card-2: #181818;
    --cdvip-border: #232323;
    --cdvip-text: #f2f2f2;
    --cdvip-text-2: #a0a0a0;
    --cdvip-text-3: #666;
    --cdvip-online: #4ade80;
}

/* Oculta el SEO intro largo (queda en DOM para crawlers vía screen-reader-text)*/
.cd-home-seo-intro { position: absolute !important; left: -9999px !important; top: auto !important; width: 1px !important; height: 1px !important; overflow: hidden !important; }

/* ── Anti-CLS: el hero del theme (cd-hero__inner) se vacía vía JS en wp_footer
   tras inyectar el VIP hero. Si dejamos que renderice con contenido en el primer
   paint, hay un shift de ~318px (PSI mobile CLS 0.39 → 0.19). Colapsamos el
   inner desde el primer paint y reservamos espacio en .cd-hero igual al alto
   final del VIP hero (medido en prod: 352 mobile, 249 desktop). */
body.home .cd-hero__inner,
body.blog .cd-hero__inner { display: none !important; }
body.home .cd-hero,
body.blog .cd-hero { min-height: 250px; }
/* Pegar la fila de historias al hero (default era padding-top:24px del .cd-layout) */
body.home .cd-layout--home { padding-top: 0; }
@media (min-width: 900px) {
    body.home .cd-hero,
    body.blog .cd-hero { min-height: 280px; }
    .cd-vip-hero__searchpill { margin-bottom: 0; }
}

/* ─── HERO VIP ─── */
.cd-hero.cd-hero--vip-mode {
    background: var(--cdvip-bg) !important;
    padding: 0 !important;
    position: relative;
    overflow: hidden;
}
.cd-hero.cd-hero--vip-mode .cd-container {
    max-width: 1200px;
    padding: 0 1.5rem;
}
.cd-vip-hero { position: relative; padding: 1.2rem 0 .4rem; }
.cd-vip-hero__bg {
    position: absolute; inset: 0;
    background:
        radial-gradient(1100px 500px at 50% 0%, rgba(200,164,92,.08), transparent 60%),
        linear-gradient(180deg, #0c0c0c 0%, #1a1611 60%, #0c0c0c 100%);
    z-index: 0;
}
.cd-vip-hero__bg::before {
    content: ""; position: absolute; inset: 0;
    background-image:
        repeating-linear-gradient(90deg, rgba(200,164,92,.04) 0 1px, transparent 1px 80px),
        radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,.7) 100%);
    opacity: .5;
}
.cd-vip-hero__inner { position: relative; z-index: 2; text-align: center; max-width: 1200px; margin: 0 auto; }

/* ─── Layout 2 columnas (hero main izq + rotación 2×2 der) ─── */
.cd-vip-hero__layout { display: grid; grid-template-columns: 1fr; gap: 1rem; align-items: start; }
@media (min-width: 900px) {
    .cd-vip-hero__layout { grid-template-columns: 300px 1fr; gap: 7rem; text-align: left; }
}
.cd-vip-hero__main { text-align: center; }
@media (min-width: 900px) {
    .cd-vip-hero__main { text-align: left; padding: 1.4rem 1.2rem; background: linear-gradient(180deg,rgba(201,168,76,.06),rgba(201,168,76,0)); border: 1px solid rgba(201,168,76,.18); border-radius: 14px; }
    .cd-vip-hero__main .cd-vip-hero__title { font-size: 1.5rem; text-align: left; margin: 0 0 1.1rem; line-height: 1.15; }
    /* Searchpill dentro del main (columna angosta 300px) apila vertical: input arriba, botón abajo. */
    .cd-vip-hero__main .cd-vip-hero__searchpill { max-width: none; flex-direction: column; border-radius: 14px; padding: .5rem; align-items: stretch; gap: .35rem; }
    .cd-vip-hero__main .cd-vip-hero__searchpill-divider { display: none; }
    .cd-vip-hero__main .cd-vip-hero__searchpill-btn { padding: .55rem 1.2rem; align-self: center; font-size: .9rem; }
}

/* ─── Bloque rotación 2×2 ─── */
.cd-vip-hero__rotation { display: grid; grid-template-columns: 1fr; gap: .75rem; min-width: 0; }
@media (min-width: 900px) {
    .cd-vip-hero__rotation { grid-template-columns: 1fr 1fr; gap: 1rem .9rem; }
}
.cd-vip-hero__rot-row { min-width: 0; text-align: left; }
.cd-vip-hero__rot-head { display: flex; align-items: center; gap: .45rem; margin: 0 0 .3rem; padding: 0 .2rem; }
.cd-vip-hero__rot-head h3 { font-family: 'Montserrat',sans-serif; font-size: .85rem; color: #fff; margin: 0; font-weight: 700; letter-spacing: .02em; text-transform: uppercase; }
.cd-vip-hero__rot-icon { font-size: 1rem; line-height: 1; }
.cd-vip-hero__rot-viewall { margin-left: auto; font-size: .7rem; color: #cc9933; text-decoration: none; font-weight: 700; white-space: nowrap; transition: color .15s; }
.cd-vip-hero__rot-viewall:hover { color: #e8b85c; text-decoration: underline; }

.cd-vip-hero__rot-strip { display: flex; gap: .7rem; overflow-x: auto; padding: .2rem .2rem .35rem; scrollbar-width: thin; justify-content: flex-start; -webkit-mask-image: linear-gradient(90deg,#000 calc(100% - 30px),transparent); mask-image: linear-gradient(90deg,#000 calc(100% - 30px),transparent); }
.cd-vip-hero__rot-strip::-webkit-scrollbar { height: 3px; }
.cd-vip-hero__rot-strip::-webkit-scrollbar-thumb { background: rgba(201,168,76,.3); border-radius: 2px; }

.cd-vip-hero__avatar { flex-shrink: 0; text-align: center; text-decoration: none; width: 64px; }
.cd-vip-hero__avatar-ring { width: 60px; height: 60px; border-radius: 50%; padding: 2.5px; background: linear-gradient(135deg,#C9A84C,#E8D5A3); display: block; margin: 0 auto .25rem; position: relative; transition: transform .15s; }
.cd-vip-hero__avatar:hover .cd-vip-hero__avatar-ring { transform: scale(1.08); }
.cd-vip-hero__avatar-inner { width: 100%; height: 100%; border-radius: 50%; overflow: hidden; background: #1a1a1a; display: block; }
.cd-vip-hero__avatar-inner img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cd-vip-hero__avatar-date { position: absolute; bottom: -3px; left: 50%; transform: translateX(-50%); background: #0F0F1A; color: #cc9933; font-size: .55rem; font-weight: 700; padding: .08rem .35rem; border-radius: 99px; border: 1px solid rgba(201,168,76,.45); white-space: nowrap; line-height: 1; }
.cd-vip-hero__avatar-name { font-size: .62rem; color: #ccc; font-weight: 700; max-width: 64px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; letter-spacing: .04em; display: block; margin-top: .35rem; }

/* Color modifiers por categoría */
.cd-vip-hero__rot-row--recien .cd-vip-hero__avatar-ring { background: linear-gradient(135deg,#a78bfa,#c4b5fd); }
.cd-vip-hero__rot-row--recien .cd-vip-hero__rot-head h3 { color: #c4b5fd; }
.cd-vip-hero__rot-row--recien .cd-vip-hero__avatar-date { color: #c4b5fd; border-color: rgba(167,139,250,.45); }
.cd-vip-hero__rot-row--volvieron .cd-vip-hero__avatar-ring { background: linear-gradient(135deg,#10b981,#34d399); }
.cd-vip-hero__rot-row--volvieron .cd-vip-hero__rot-head h3 { color: #6ee7b7; }
.cd-vip-hero__rot-row--volvieron .cd-vip-hero__avatar-date { color: #6ee7b7; border-color: rgba(16,185,129,.45); }
.cd-vip-hero__rot-row--fotos .cd-vip-hero__avatar-ring { background: linear-gradient(135deg,#fb923c,#fdba74); }
.cd-vip-hero__rot-row--fotos .cd-vip-hero__rot-head h3 { color: #fdba74; }
.cd-vip-hero__rot-row--fotos .cd-vip-hero__avatar-date { color: #fdba74; border-color: rgba(251,146,60,.45); }
.cd-vip-hero__rot-row--video .cd-vip-hero__avatar-ring { background: linear-gradient(135deg,#f43f5e,#fda4af); }
.cd-vip-hero__rot-row--video .cd-vip-hero__rot-head h3 { color: #fda4af; }
.cd-vip-hero__rot-row--video .cd-vip-hero__avatar-date { color: #fda4af; border-color: rgba(244,63,94,.45); }
.cd-vip-hero__rot-row--video .cd-vip-hero__avatar-ring::before { content: '▶'; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); color: rgba(255,255,255,.95); font-size: 1.1rem; z-index: 3; text-shadow: 0 2px 6px rgba(0,0,0,.7); pointer-events: none; }

/* ─── Mobile tabs (solo <900px) — estilo RelaxChile: tabs en fila, 1 activa con borde ─── */
.cd-vip-hero__mtabs { display: none; }
@media (max-width: 899px) {
    .cd-vip-hero__mtabs { display: flex; gap: .35rem; overflow-x: auto; scrollbar-width: none; padding: 0 0 .3rem; scroll-behavior: smooth; -webkit-mask-image: linear-gradient(90deg,#000 0,#000 calc(100% - 18px),transparent 100%); mask-image: linear-gradient(90deg,#000 0,#000 calc(100% - 18px),transparent 100%); }
    .cd-vip-hero__mtabs::-webkit-scrollbar { display: none; }
    .cd-vip-hero__mtab { flex: 0 0 auto; padding: .5rem .85rem; border-radius: 6px; background: transparent; border: 1px solid transparent; color: #999; font-size: .82rem; font-weight: 600; cursor: pointer; font-family: inherit; transition: all .15s; white-space: nowrap; line-height: 1.15; display: inline-flex; align-items: center; gap: .35rem; }
    .cd-vip-hero__mtab:hover { color: #ccc; }
    .cd-vip-hero__mtab.is-active { color: #fff; border-color: #fff; }
    .cd-vip-hero__mtab-icon { font-size: 1em; line-height: 1; }
    .cd-vip-hero__rotation .cd-vip-hero__rot-row { display: none; }
    .cd-vip-hero__rotation .cd-vip-hero__rot-row.is-active { display: block; }
    /* En mobile el icono + título del row son redundantes con la tab activa (la tab ya muestra icono y label); solo mantenemos "Ver todas →" */
    .cd-vip-hero__rot-row .cd-vip-hero__rot-icon,
    .cd-vip-hero__rot-row .cd-vip-hero__rot-head h3 { display: none; }
    .cd-vip-hero__rot-head { justify-content: flex-end; margin: 0 0 .25rem; }
    /* Centrar avatares en mobile: reducir gap + ring slightly para que 5 entren cómodos */
    .cd-vip-hero__rot-strip { gap: .35rem; justify-content: center; }
    .cd-vip-hero__avatar { width: 60px; }
    .cd-vip-hero__avatar-ring { width: 56px; height: 56px; }
    .cd-vip-hero__avatar-name { max-width: 60px; }
}

.cd-vip-hero__title {
    font-family: 'Montserrat','Helvetica Neue',sans-serif;
    font-size: clamp(1.6rem, 4vw, 2.4rem);
    font-weight: 800;
    color: #fff;
    margin: 0 0 .55rem;
    letter-spacing: -.01em;
    line-height: 1.05;
    text-transform: uppercase;
}
.cd-vip-hero__title span { color: var(--cdvip-gold); }
.cd-vip-hero__subtitle {
    color: var(--cdvip-text-2);
    font-size: clamp(.85rem, 1.3vw, .95rem);
    max-width: 540px;
    margin: 0 auto .9rem;
    line-height: 1.5;
}

/* Search pill */
.cd-vip-hero__searchpill {
    background: rgba(20,20,20,.85);
    backdrop-filter: blur(16px);
    border: 1px solid var(--cdvip-border);
    border-radius: 999px;
    padding: .35rem .35rem .35rem 1rem;
    display: flex; align-items: center;
    max-width: 760px;
    margin: 0 auto .9rem;
    gap: .25rem;
    box-shadow: 0 12px 40px -10px rgba(0,0,0,.6);
}
.cd-vip-hero__searchpill-field { display: flex; align-items: center; gap: .5rem; padding: .55rem .9rem; flex: 0 1 auto; min-width: 0; }
.cd-vip-hero__searchpill-field--input { flex: 1 1 0; }
.cd-vip-hero__searchpill-field svg { color: var(--cdvip-gold); flex-shrink: 0; }
.cd-vip-hero__searchpill-field select,
.cd-vip-hero__searchpill-field input {
    background: transparent; border: none; outline: none;
    color: var(--cdvip-text);
    font-size: .9rem;
    font-family: inherit;
    width: 100%;
    appearance: none;
    cursor: pointer;
}
.cd-vip-hero__searchpill-field select option { background: #1a1a1a; color: #fff; }
.cd-vip-hero__searchpill-field input { cursor: text; }
.cd-vip-hero__searchpill-divider {
    width: 1px; height: 24px; background: var(--cdvip-border); flex-shrink: 0;
}
.cd-vip-hero__searchpill-btn {
    background: linear-gradient(135deg, var(--cdvip-gold), var(--cdvip-gold-2));
    color: #1a1a1a;
    border: none;
    padding: .85rem 1.6rem;
    border-radius: 999px;
    font-weight: 700;
    font-size: .9rem;
    cursor: pointer;
    transition: transform .15s, box-shadow .15s;
    flex-shrink: 0;
}
.cd-vip-hero__searchpill-btn:hover { transform: translateY(-1px); box-shadow: 0 6px 18px -6px rgba(200,164,92,.5); }

/* Autocomplete dropdown — sugerencias enlazadas (rastreables) */
/* El theme aplica overflow:hidden al .cd-hero. Lo overridemos para que el dropdown se vea */
.cd-hero.cd-hero--vip-mode { overflow: visible !important; }
.cd-vip-hero__searchpill { position: relative; z-index: 30; }
.cd-hero-suggest {
    position: absolute; top: calc(100% + 8px); left: 0; right: 0;
    margin: 0; padding: 6px; list-style: none;
    background: rgba(20, 20, 20, .96); backdrop-filter: blur(10px);
    border: 1px solid rgba(204, 153, 51, .3); border-radius: 14px;
    max-height: 360px; overflow-y: auto;
    box-shadow: 0 12px 40px -10px rgba(0,0,0,.6);
    z-index: 50;
    /* Hidden by default; visible cuando .is-open o cuando :focus dentro del form (fallback CSS-only) */
    opacity: 0; visibility: hidden; transform: translateY(-4px);
    transition: opacity .15s, visibility .15s, transform .15s;
}
.cd-hero-suggest.is-open { opacity: 1; visibility: visible; transform: translateY(0); }
.cd-hero-suggest li { margin: 0; }
.cd-hero-suggest a {
    display: block; padding: .55rem .9rem; color: #ddd; text-decoration: none;
    font-size: .92rem; border-radius: 8px;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cd-hero-suggest a:hover, .cd-hero-suggest li.is-highlighted a {
    background: rgba(204, 153, 51, .15); color: #fff;
}
.cd-hero-suggest::-webkit-scrollbar { width: 6px; }
.cd-hero-suggest::-webkit-scrollbar-thumb { background: rgba(204,153,51,.3); border-radius: 3px; }
@media (max-width: 760px) {
    .cd-hero-suggest { max-height: 280px; }
}

@media (max-width: 760px) {
    /* Input + botón en MISMA fila: input flex-grow, botón compacto a la derecha */
    .cd-vip-hero__searchpill {
        flex-direction: row; border-radius: 999px; padding: .3rem .3rem .3rem 1rem; align-items: center; gap: .35rem;
    }
    .cd-vip-hero__searchpill-field { padding: .35rem 0; }
    .cd-vip-hero__searchpill-divider { display: none; }
    .cd-vip-hero__searchpill-btn { padding: .55rem 1rem; font-size: .85rem; flex-shrink: 0; }
}

/* Compactar hero en mobile: padding, gaps y márgenes más chicos. Movido DESPUÉS de las reglas base para ganar especificidad de orden. */
@media (max-width: 899px) {
    .cd-vip-hero { padding: .5rem 0 0; }
    .cd-vip-hero__layout { gap: .4rem; }
    /* Título h1 en 1 línea, maximizado para llenar viewport (responsive con clamp) */
    .cd-vip-hero__title { font-size: clamp(.95rem, 4.55vw, 1.2rem); margin: 0 0 .4rem; white-space: nowrap; letter-spacing: -.02em; }
    .cd-vip-hero__searchpill { margin-bottom: .35rem; }
    /* Strip de avatares con menos padding bottom (era .35rem) */
    .cd-vip-hero__rotation .cd-vip-hero__rot-strip { padding: .2rem .2rem 0; }
    .cd-vip-hero__rotation .cd-vip-hero__rot-row { padding-bottom: 0; }
}

/* Chips — ocultos en mobile (las tabs ya cumplen ese rol) y en desktop (el sidebar lo hace). */
.cd-vip-hero__chips { display: none; }
.cd-vip-hero__chip {
    display: inline-flex; align-items: center; gap: .55rem;
    padding: .7rem 1.3rem;
    background: rgba(20,20,20,.85);
    backdrop-filter: blur(12px);
    border: 1px solid var(--cdvip-border);
    border-radius: 999px;
    color: var(--cdvip-text);
    text-decoration: none;
    font-size: .85rem;
    font-weight: 500;
    transition: all .15s;
}
.cd-vip-hero__chip svg { color: var(--cdvip-gold); }
.cd-vip-hero__chip:hover {
    border-color: var(--cdvip-gold);
    background: rgba(200,164,92,.08);
    transform: translateY(-1px);
}
/* Modificadores específicos */
.cd-vip-hero__chip--live { border-color: rgba(74,222,128,.35); }
.cd-vip-hero__chip--live:hover { border-color: var(--cdvip-online); background: rgba(74,222,128,.08); }
.cd-vip-hero__chip-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--cdvip-online);
    box-shadow: 0 0 0 0 rgba(74,222,128,.6);
    animation: cdChipLive 1.8s ease-in-out infinite;
}
@keyframes cdChipLive {
    0%,100% { box-shadow: 0 0 0 0 rgba(74,222,128,.55); }
    50%     { box-shadow: 0 0 0 6px rgba(74,222,128,0); }
}
.cd-vip-hero__chip--verif svg { color: #8de0a8; }
@media (prefers-reduced-motion: reduce) {
    .cd-vip-hero__chip-dot { animation: none; }
}
@media (max-width: 760px) {
    .cd-vip-hero__chips { gap: .5rem; margin-top: .5rem; }
    .cd-vip-hero__chip { padding: .55rem .9rem; font-size: .8rem; }
}

/* ─── VIP SHOWCASE (3 large cards) ─── */
.cd-vip-showcase { margin: 1rem 0 2rem; }
.cd-vip-showcase__head {
    display: flex; justify-content: space-between; align-items: end;
    margin-bottom: .85rem; gap: 1rem;
}
.cd-vip-showcase__title {
    font-family: 'Montserrat',sans-serif;
    font-size: 1.6rem; font-weight: 800;
    color: #fff;
    margin: 0; letter-spacing: -.01em;
    text-transform: uppercase;
}
.cd-vip-showcase__subtitle {
    color: var(--cdvip-text-2); font-size: .9rem; margin: .25rem 0 0;
}
.cd-vip-showcase__viewall {
    color: var(--cdvip-gold); text-decoration: none; font-size: .9rem; font-weight: 600;
}
.cd-vip-showcase__viewall:hover { color: #fff; }
.cd-vip-showcase__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.2rem;
}
@media (max-width: 880px) {
    .cd-vip-showcase__grid { grid-template-columns: 1fr; }
}
.cd-vip-showcase__card {
    position: relative; display: block;
    aspect-ratio: 1/1;
    border-radius: 14px;
    overflow: hidden;
    background: var(--cdvip-bg-card);
    border: 1px solid var(--cdvip-border);
    text-decoration: none;
    transition: transform .2s, border-color .2s;
}
.cd-vip-showcase__card:hover { transform: translateY(-3px); border-color: var(--cdvip-gold); }
.cd-vip-showcase__card img {
    position: absolute; inset: 0;
    width: 100%; height: 100%; object-fit: cover; display: block;
}
.cd-vip-showcase__card::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,.85) 100%);
    pointer-events: none;
}
.cd-vip-showcase__verified {
    position: absolute; top: 14px; right: 14px; z-index: 2;
    display: inline-flex; align-items: center; gap: .3rem;
    background: rgba(0,0,0,.7); backdrop-filter: blur(8px);
    color: var(--cdvip-gold);
    border: 1px solid rgba(200,164,92,.4);
    padding: .3rem .65rem;
    border-radius: 4px;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
}
.cd-vip-showcase__online {
    position: absolute; bottom: 80px; left: 14px; z-index: 2;
    display: inline-flex; align-items: center; gap: .35rem;
    background: rgba(0,0,0,.6); backdrop-filter: blur(8px);
    color: var(--cdvip-online);
    padding: .3rem .65rem;
    border-radius: 999px;
    font-size: .7rem; font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.cd-vip-showcase__online span {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--cdvip-online);
    box-shadow: 0 0 8px rgba(74,222,128,.6);
}
.cd-vip-showcase__caption {
    position: absolute; bottom: 16px; left: 16px; right: 16px; z-index: 2;
}
.cd-vip-showcase__caption strong {
    display: block; color: #fff;
    font-family: 'Montserrat',sans-serif;
    font-size: 1.3rem; font-weight: 700;
    letter-spacing: .02em;
    margin-bottom: .15rem;
}
.cd-vip-showcase__caption span {
    color: var(--cdvip-text-2); font-size: .85rem;
}

/* ─── NEW ARRIVALS ─── */
.cd-new-arrivals { margin: 3rem 0; padding: 2rem 0; border-top: 1px solid var(--cdvip-border); border-bottom: 1px solid var(--cdvip-border); }
.cd-new-arrivals__head {
    display: flex; justify-content: space-between; align-items: end; gap: 1rem;
    margin-bottom: 1.5rem; flex-wrap: wrap;
}
.cd-new-arrivals__title {
    font-family: 'Montserrat',sans-serif;
    font-size: 1.4rem; font-weight: 800; color: #fff;
    margin: 0; text-transform: uppercase; letter-spacing: -.01em;
}
.cd-new-arrivals__subtitle { color: var(--cdvip-text-2); font-size: .85rem; margin: .25rem 0 0; }
.cd-new-arrivals__filters { display: flex; gap: .35rem; }
.cd-new-arrivals__filter {
    background: var(--cdvip-bg-card);
    color: var(--cdvip-text-2);
    border: 1px solid var(--cdvip-border);
    padding: .4rem 1rem; border-radius: 999px;
    font-size: .8rem; font-weight: 600;
    cursor: pointer; transition: all .15s;
}
.cd-new-arrivals__filter.is-active {
    background: linear-gradient(135deg, var(--cdvip-gold), var(--cdvip-gold-2));
    color: #1a1a1a; border-color: transparent;
}
.cd-new-arrivals__row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
    gap: 1.5rem;
    overflow-x: auto;
}
.cd-new-arrivals__item {
    display: flex; flex-direction: column; align-items: center; gap: .5rem;
    text-decoration: none;
    transition: transform .15s;
}
.cd-new-arrivals__item:hover { transform: translateY(-2px); }
.cd-new-arrivals__avatar {
    width: 90px; height: 90px;
    border-radius: 50%; overflow: hidden;
    background: var(--cdvip-bg-card);
    border: 2px solid var(--cdvip-border);
    transition: border-color .15s;
}
.cd-new-arrivals__item:hover .cd-new-arrivals__avatar { border-color: var(--cdvip-gold); }
.cd-new-arrivals__avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cd-new-arrivals__item strong {
    color: var(--cdvip-text); font-size: .85rem; font-weight: 600; text-align: center;
}
.cd-new-arrivals__item small { color: var(--cdvip-text-3); font-size: .7rem; text-align: center; }
.cd-new-arrivals__more { text-align: center; margin-top: 2rem; }
.cd-new-arrivals__more-btn {
    display: inline-block;
    padding: .85rem 2rem;
    border: 1px solid var(--cdvip-gold);
    color: var(--cdvip-gold);
    border-radius: 8px;
    text-decoration: none;
    font-weight: 600;
    font-size: .9rem;
    transition: all .15s;
}
.cd-new-arrivals__more-btn:hover {
    background: var(--cdvip-gold); color: #1a1a1a;
}

/* ─── DISCREET UPDATES (Newsletter) ─── */
.cd-discreet {
    margin: 3rem 0 0;
    padding: 3rem 1.5rem;
    background: linear-gradient(180deg, #0c0c0c 0%, #1a1611 100%);
    border-top: 1px solid var(--cdvip-border);
}
.cd-discreet__grid {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: center;
}
@media (max-width: 880px) { .cd-discreet__grid { grid-template-columns: 1fr; gap: 2rem; } }
.cd-discreet__title {
    font-family: 'Montserrat',sans-serif;
    font-size: 1.4rem; font-weight: 800; color: #fff;
    margin: 0 0 1rem; text-transform: uppercase; letter-spacing: -.01em;
}
.cd-discreet__intro p {
    color: var(--cdvip-text-2); margin: 0 0 1.5rem; line-height: 1.6; font-size: .95rem;
}
.cd-discreet__form { display: flex; gap: .5rem; max-width: 460px; flex-wrap: wrap; }
.cd-discreet__form input {
    flex: 1 1 240px;
    padding: .85rem 1.2rem;
    background: var(--cdvip-bg-card);
    border: 1px solid var(--cdvip-border);
    border-radius: 8px;
    color: var(--cdvip-text); font-size: .9rem;
    outline: none;
}
.cd-discreet__form input:focus { border-color: var(--cdvip-gold); }
.cd-discreet__btn {
    padding: .85rem 1.6rem;
    background: linear-gradient(135deg, var(--cdvip-gold), var(--cdvip-gold-2));
    color: #1a1a1a; border: none; border-radius: 8px;
    font-weight: 700; font-size: .9rem; cursor: pointer;
}
.cd-discreet__cards { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 480px) { .cd-discreet__cards { grid-template-columns: 1fr; } }
.cd-discreet__card {
    background: var(--cdvip-bg-card);
    border: 1px solid var(--cdvip-border);
    border-radius: 12px;
    padding: 1.5rem;
}
.cd-discreet__icon {
    display: inline-flex; width: 42px; height: 42px;
    align-items: center; justify-content: center;
    background: var(--cdvip-gold-soft);
    color: var(--cdvip-gold);
    border-radius: 10px; margin-bottom: 1rem;
}
.cd-discreet__card strong {
    display: block; color: #fff; font-weight: 700; font-size: 1.05rem;
    margin-bottom: .35rem;
}
.cd-discreet__card p { color: var(--cdvip-text-2); font-size: .85rem; margin: 0; line-height: 1.5; }

/* ─── CARDS GALLERY OVERRIDE (full-bleed, name overlay) ─── */
.cd-grid.cd-grid--cards {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)) !important;
    gap: 6px !important;
    background: transparent !important;
}
@media (min-width: 1100px) {
    .cd-grid.cd-grid--cards { grid-template-columns: repeat(5, 1fr) !important; }
}
@media (min-width: 1400px) {
    .cd-grid.cd-grid--cards { grid-template-columns: repeat(5, 1fr) !important; }
}

/* Sección "Estándar" (perfiles gratis) — 7 columnas en desktop para mostrar más
   densidad. Mobile/tablet hereda el auto-fill por defecto. */
@media (min-width: 1100px) {
    .cd-cat-section--gratis .cd-grid.cd-grid--cards {
        grid-template-columns: repeat(7, 1fr) !important;
    }
}

article.cd-card.cd-card--perfil {
    position: relative !important;
    aspect-ratio: 3/4 !important;
    background: var(--cdvip-bg-card) !important;
    border-radius: 4px !important;
    overflow: hidden !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    transition: transform .15s !important;
}
article.cd-card.cd-card--perfil:hover { transform: scale(1.01); z-index: 2; }

article.cd-card.cd-card--perfil .cd-card__thumb-link {
    position: absolute !important; inset: 0 !important;
    display: block !important;
    width: 100% !important; height: 100% !important;
    margin: 0 !important; padding: 0 !important;
}
article.cd-card.cd-card--perfil .cd-card__thumb {
    position: absolute !important; inset: 0 !important;
    width: 100% !important; height: 100% !important;
    object-fit: cover !important;
    object-position: center top !important;
    border-radius: 0 !important;
    margin: 0 !important;
}

/* Sobre el thumb: gradient overlay para legibilidad del nombre */
article.cd-card.cd-card--perfil::after {
    content: "" !important; position: absolute !important; inset: 0 !important;
    background: linear-gradient(180deg, rgba(0,0,0,.0) 50%, rgba(0,0,0,.85) 100%) !important;
    pointer-events: none !important; z-index: 1 !important;
}

/* Badges arriba (NEW, VIP, ELITE, DESTACADA) */
article.cd-card.cd-card--perfil .cd-card__badges-top {
    position: absolute !important; top: 8px !important; left: 8px !important;
    display: flex !important; flex-direction: column !important; gap: 4px !important;
    z-index: 2 !important;
}
article.cd-card.cd-card--perfil .cd-badge {
    display: inline-flex !important;
    padding: 3px 8px !important;
    font-size: .55rem !important;
    font-weight: 800 !important;
    letter-spacing: .08em !important;
    border-radius: 3px !important;
    text-transform: uppercase !important;
    backdrop-filter: blur(4px) !important;
}

/* Star top right */
article.cd-card.cd-card--perfil .cd-card__icons-top {
    position: absolute !important; top: 8px !important; right: 8px !important;
    z-index: 3 !important;
}
article.cd-card.cd-card--perfil .cd-card__icon-badge {
    background: rgba(0,0,0,.55) !important;
    backdrop-filter: blur(8px) !important;
    border: 1px solid rgba(255,255,255,.18) !important;
    width: 32px !important; height: 32px !important;
    border-radius: 50% !important;
    color: #fff !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    transition: background .15s, color .15s, transform .15s !important;
}
article.cd-card.cd-card--perfil .cd-card__icon-badge svg {
    width: 16px !important; height: 16px !important;
    stroke: currentColor !important;
    fill: none !important;
    flex-shrink: 0 !important;
}
article.cd-card.cd-card--perfil .cd-card__icon-badge:hover {
    color: var(--cdvip-gold, #c9a84c) !important;
    background: rgba(0,0,0,.75) !important;
    transform: scale(1.08) !important;
}
article.cd-card.cd-card--perfil .cd-card__icon-badge--fav[aria-pressed="true"] {
    color: #ff5577 !important;
    background: rgba(255,85,119,.18) !important;
    border-color: rgba(255,85,119,.45) !important;
}
article.cd-card.cd-card--perfil .cd-card__icon-badge--fav[aria-pressed="true"] svg {
    fill: #ff5577 !important;
}

/* Info inferior — name + comuna superpuesto sobre el gradient */
article.cd-card.cd-card--perfil .cd-card__info,
article.cd-card.cd-card--perfil .cd-card__body,
article.cd-card.cd-card--perfil .cd-card__footer {
    position: absolute !important;
    bottom: 0 !important; left: 0 !important; right: 0 !important;
    padding: 12px 14px 14px !important;
    background: transparent !important;
    z-index: 2 !important;
    pointer-events: none !important;
    display: block !important;
}
article.cd-card.cd-card--perfil .cd-card__info > a,
article.cd-card.cd-card--perfil .cd-card__name,
article.cd-card.cd-card--perfil h3,
article.cd-card.cd-card--perfil h2 {
    color: #fff !important;
    font-family: 'Montserrat',sans-serif !important;
    font-size: 1.1rem !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: .04em !important;
    text-decoration: none !important;
    line-height: 1.2 !important;
    margin: 0 0 4px !important;
    text-shadow: 0 2px 6px rgba(0,0,0,.7) !important;
    pointer-events: auto !important;
    display: block !important;
}
article.cd-card.cd-card--perfil .cd-card__meta {
    color: rgba(255,255,255,.85) !important;
    font-size: .75rem !important;
    font-weight: 500 !important;
    text-shadow: 0 1px 3px rgba(0,0,0,.7) !important;
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: .35rem !important;
    margin: 0 !important;
}
article.cd-card.cd-card--perfil .cd-card__meta > * + *::before {
    content: "·" !important;
    margin-right: .35rem !important;
    opacity: .6 !important;
}

/* Tooltip (hover details) keep but adjust */
article.cd-card.cd-card--perfil .cd-card__tooltip {
    z-index: 4 !important;
}

/* Hide section headers' decorative bars and adjust spacing */
.cd-cat-section__header {
    margin-bottom: 1rem !important;
}
.cd-cat-section { margin-bottom: 2.5rem !important; }

/* Sidebar visual tweak */
.cd-layout--home .cd-layout__sidebar { display: none !important; }
.cd-layout--home .cd-layout__primary { width: 100% !important; max-width: 100% !important; }
.cd-layout--home { display: block !important; }
@media (min-width: 1024px) {
    .cd-layout--home { grid-template-columns: 1fr !important; display: block !important; }
}

/* Regional sections: ocultas en home por carga (4 grillas adicionales era demasiado) */
.cd-regional-sections { display: none !important; }
