/* ===== EscortsColombiaVIP — tema dark premium ===== */
:root{
  --bg:#0a0a0c; --bg2:#101014; --card:#16161c; --card2:#1d1d25;
  --line:#26262f; --txt:#f4f1ea; --muted:#9a96a3;
  --gold:#e21d7a; --gold2:#ff4da6; --rose:#e0436b; --fucsia:#e21d7a; --fucsia2:#ff3d96;
  --ok:#27c08a; --warn:#e0a23a; --bad:#e0556b;
  --r:16px; --shadow:0 18px 50px -18px rgba(0,0,0,.7);
  --maxw:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{overflow-x:clip;max-width:100%}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(226,29,122,.10), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(224,67,107,.08), transparent 55%),
    var(--bg);
  color:var(--txt);
  font-family:'Inter','Segoe UI',system-ui,-apple-system,sans-serif;
  line-height:1.55; -webkit-font-smoothing:antialiased; min-height:100vh;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.gold{color:var(--gold)}
h1,h2,h3{font-family:'Anton','Inter',sans-serif;font-weight:400;line-height:1.06;text-transform:uppercase;letter-spacing:.01em}
.section{padding:54px 0}
.muted{color:var(--muted)}

/* ===== Header ===== */
.hdr{position:sticky;top:0;z-index:50;background:rgba(10,10,12,.72);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--line);transition:.3s}
.hdr .bar{display:flex;align-items:center;gap:18px;height:72px}
.wordmark{font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;font-weight:800;font-size:1.6rem;
  letter-spacing:-.6px;color:#fff;display:inline-flex;align-items:baseline;gap:9px;line-height:1;white-space:nowrap}
.wordmark span{font-weight:600;font-size:.6rem;letter-spacing:3.5px;text-transform:uppercase;color:var(--gold);
  transform:translateY(-1px)}
.wordmark-ag{font-size:2rem;justify-content:center;margin-bottom:18px}
/* selector de ciudad junto al logo */
.city-switch{flex:0 0 auto}
.city-switch .csel{width:auto}
.city-switch .csel-btn{min-width:130px;padding:9px 13px;border-radius:999px;background:var(--card);font-size:.9rem}
.city-switch .csel-btn::before{content:"";width:1.05em;height:1.05em;flex:none;background:currentColor;color:var(--gold);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M20 10c0 6-8 12-8 12s-8-6-8-12a8 8 0 0 1 16 0Z'/><circle cx='12' cy='10' r='3'/></svg>") center/contain no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M20 10c0 6-8 12-8 12s-8-6-8-12a8 8 0 0 1 16 0Z'/><circle cx='12' cy='10' r='3'/></svg>") center/contain no-repeat}
.bar-right{margin-left:auto;display:flex;align-items:center;gap:8px}
.btn-search{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:999px;
  background:var(--card);border:1px solid var(--line);color:var(--txt);font-size:.92rem;font-weight:500;
  cursor:pointer;font-family:inherit;transition:.2s;white-space:nowrap}
.btn-search:hover{border-color:var(--gold);color:var(--gold)}
.btn-search .ico{color:var(--gold);transition:.2s}
.btn-search:hover .ico{color:var(--gold)}
.nav{display:flex;align-items:center;gap:6px}
.nav a{padding:9px 14px;border-radius:10px;font-size:.92rem;color:var(--muted);transition:.2s;white-space:nowrap}
.nav a:hover{color:var(--txt);background:var(--card)}
.nav a.btn-fucsia,.nav a.btn-gold{color:#fff}
.nav a.btn-fucsia:hover,.nav a.btn-gold:hover{color:#fff;background:initial}
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 20px;border-radius:12px;
  font-weight:600;border:none;cursor:pointer;font-size:.95rem;transition:.25s;font-family:inherit}
.btn-gold{background:linear-gradient(135deg,var(--gold2),var(--gold));color:#fff;
  box-shadow:0 8px 24px -8px rgba(226,29,122,.6)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 12px 30px -8px rgba(226,29,122,.8)}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--txt)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-fucsia{background:linear-gradient(135deg,var(--fucsia2),var(--fucsia));color:#fff;
  box-shadow:0 8px 24px -8px rgba(226,29,122,.65)}
.btn-fucsia:hover{transform:translateY(-2px);box-shadow:0 12px 30px -8px rgba(226,29,122,.85);color:#fff}
.btn-wa{background:#25d366;color:#062f15}
.btn-wa:hover{transform:translateY(-2px);filter:brightness(1.08)}
.btn-block{width:100%;justify-content:center}
.ico{width:1.05em;height:1.05em;display:inline-block;vertical-align:-.15em;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round;flex:none}
.ico-lg{width:1.5em;height:1.5em}
.menu-tog{display:none;background:none;border:none;color:var(--txt);font-size:1.6rem;cursor:pointer}

/* ===== Hero ===== */
.hero{position:relative;padding:78px 0 40px;text-align:center;overflow:hidden}
/* al abrir un dropdown del buscador, dejar que el menú se salga del hero (no recortarlo) */
.hero:has(.csel.open){overflow:visible}
.hero h1{font-size:clamp(2.2rem,5vw,3.6rem);letter-spacing:-.5px}
.hero h1 .gold{background:linear-gradient(135deg,var(--gold2),var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p{color:var(--muted);max-width:620px;margin:16px auto 0;font-size:1.08rem}
.hero .dots{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:26px 26px;mask:radial-gradient(60% 60% at 50% 30%,#000,transparent);pointer-events:none}

/* ===== Hero compacto (home directorio) ===== */
.hero-slim{padding:48px 0 26px}
.hero-slim h1{font-size:clamp(1.8rem,4vw,2.8rem)}
.hero-slim p{margin-top:10px;font-size:1rem}
.section-tight{padding:26px 0}

/* buscador unificado tipo barra */
.searchbar{display:flex;align-items:stretch;gap:8px;max-width:880px;margin:26px auto 0;position:relative;z-index:2;
  background:var(--card);border:1px solid var(--line);border-radius:14px;padding:8px;flex-wrap:wrap;
  box-shadow:0 18px 50px -24px rgba(0,0,0,.8)}
.searchbar .sb-ico{display:none}
/* fila 1: el input ocupa todo el ancho */
.searchbar input[type=text]{flex:1 1 100%;width:auto;min-width:0;background:transparent;border:none;color:var(--txt);
  padding:10px 14px;font-size:.96rem;font-family:inherit}
.searchbar input[type=text]:focus{outline:none}
/* fila 2: dropdowns (ciudad/barrio/categoría) + botón, repartidos */
.searchbar .csel{flex:1 1 150px;min-width:0;width:auto}
.searchbar select{flex:1 1 150px;width:auto;min-width:0;background:var(--bg2);border:1px solid var(--line);color:var(--txt);
  padding:11px 14px;border-radius:10px;font-size:.92rem;font-family:inherit;cursor:pointer;transition:.2s}
.searchbar select:focus{outline:none;border-color:var(--gold)}
.searchbar .btn{flex:1 1 140px;border-radius:10px;justify-content:center}

/* píldoras de ciudad */
.city-pills{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:18px;position:relative;z-index:2}
.city-pill{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:999px;border:1px solid var(--line);
  background:rgba(22,22,28,.6);color:var(--muted);font-size:.86rem;transition:.22s}
.city-pill .ico{width:.95em;height:.95em;color:var(--gold)}
.city-pill:hover{border-color:var(--gold);color:var(--txt);transform:translateY(-2px);background:var(--card)}

/* chips con scroll horizontal en móvil */
.chips-scroll{margin:0 0 28px;justify-content:flex-start}

/* ===== Filtros ===== */
.filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:30px;position:relative;z-index:2}
.filters select,.filters input{background:var(--card);border:1px solid var(--line);color:var(--txt);
  padding:12px 16px;border-radius:12px;font-size:.95rem;font-family:inherit;min-width:150px;transition:.2s}
.filters select:focus,.filters input:focus{outline:none;border-color:var(--gold)}

/* ===== Dropdown propio (reemplaza el select nativo) ===== */
.csel{position:relative;font-family:inherit;width:100%}
.csel-btn{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;
  background:var(--bg2);border:1px solid var(--line);color:var(--txt);padding:12px 14px;border-radius:11px;
  font-size:.95rem;line-height:1.2;cursor:pointer;font-family:inherit;text-align:left;transition:.2s}
.csel-btn:hover{border-color:var(--gold)}
.csel.open .csel-btn{border-color:var(--gold);box-shadow:0 0 0 3px rgba(226,29,122,.12)}
.csel-lbl{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.csel-btn .chev{width:1.15em;height:1.15em;color:var(--muted);flex:none;transition:.25s}
.csel.open .csel-btn .chev{transform:rotate(180deg);color:var(--gold)}
.csel-menu{position:absolute;z-index:70;top:calc(100% + 6px);left:0;right:0;background:var(--card2);
  border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:6px;max-height:300px;
  overflow:auto;display:none;overscroll-behavior:contain}
.csel.open .csel-menu{display:block;animation:cselin .16s ease}
@keyframes cselin{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.csel-search{width:100%;background:var(--bg);border:1px solid var(--line);color:var(--txt);
  padding:9px 12px;border-radius:9px;font-size:.9rem;font-family:inherit;margin-bottom:6px}
.csel-search:focus{outline:none;border-color:var(--gold)}
.csel-opt{padding:10px 12px;border-radius:8px;font-size:.92rem;color:var(--txt);cursor:pointer;transition:.12s;
  font-family:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.csel-opt:hover,.csel-opt.hl{background:var(--card)}
.csel-opt.sel{color:var(--gold2);font-weight:600;background:rgba(226,29,122,.08)}
.csel-empty{padding:12px;color:var(--muted);font-size:.88rem;text-align:center}
.csel-menu::-webkit-scrollbar{width:9px}
.csel-menu::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}
.csel-menu::-webkit-scrollbar-track{background:transparent}
/* ancho auto cuando el dropdown vive en una fila flex (buscador / filtros) */
.searchbar .csel,.filters .csel{width:auto;flex:0 0 auto}
.searchbar .csel-btn{min-width:150px}
.filters .csel-btn{min-width:160px}
.searchbar .csel{margin:0 4px}
/* el contenedor con un dropdown abierto debe quedar sobre pills/chips/cards */
.searchbar:has(.csel.open),.filters:has(.csel.open){z-index:60}

/* chips de categorías/género */
.chips{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;margin-top:22px;position:relative;z-index:2}
.chip{padding:8px 16px;border-radius:999px;border:1px solid var(--line);background:var(--card);
  color:var(--muted);font-size:.88rem;transition:.22s;cursor:pointer}
.chip:hover{border-color:var(--gold);color:var(--txt);transform:translateY(-2px)}
.chip.on{background:linear-gradient(135deg,var(--gold2),var(--gold));color:#fff;border-color:transparent;font-weight:600}

/* ===== Pestañas de etiquetas (home) ===== */
.etabs{margin:6px 0 30px}
.etabs-tabs{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:18px}
.etab{display:inline-flex;align-items:center;gap:8px;font-family:'Anton','Inter',sans-serif;text-transform:uppercase;letter-spacing:.04em;
  padding:9px 20px;border-radius:999px;border:1px solid var(--line);background:var(--card);
  color:var(--muted);font-size:.92rem;cursor:pointer;transition:.2s}
.etab .ico{width:1.05em;height:1.05em;color:var(--gold);transition:.2s}
.etab:hover{border-color:var(--gold);color:var(--txt)}
.etab.on .ico{color:#fff}
.etab.on{background:linear-gradient(135deg,var(--gold2),var(--gold));color:#fff;border-color:transparent}
.etab-panel{display:none;flex-wrap:wrap;gap:9px;justify-content:center;animation:cselin .2s ease}
.etab-panel.on{display:flex}

/* ===== Popup de búsqueda ===== */
.searchmodal[hidden]{display:none}
.searchmodal{position:fixed;inset:0;z-index:200;display:flex;align-items:flex-start;justify-content:center;
  padding:5vh 16px;overflow-y:auto}
.sm-backdrop{position:fixed;inset:0;background:rgba(5,5,7,.78);backdrop-filter:blur(6px)}
.sm-box{position:relative;width:100%;max-width:560px;background:var(--bg2);border:1px solid var(--line);
  border-radius:20px;box-shadow:var(--shadow);padding:24px;animation:cselin .22s ease}
.sm-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.sm-head h2{font-size:1.5rem}
.sm-close{background:var(--card);border:1px solid var(--line);color:var(--txt);width:38px;height:38px;
  border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s}
.sm-close:hover{border-color:var(--gold);color:var(--gold)}
.sm-form{display:flex;flex-direction:column;gap:16px}
.sm-search{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--line);
  border-radius:12px;padding:0 14px}
.sm-search .ico{color:var(--muted);flex:none}
.sm-search input{flex:1;background:transparent;border:none;color:var(--txt);padding:14px 0;font-size:1rem;font-family:inherit}
.sm-search input:focus{outline:none}
.sm-geo{display:inline-flex;align-items:center;justify-content:center;gap:8px;align-self:flex-start;
  background:linear-gradient(135deg,rgba(255,77,166,.16),rgba(226,29,122,.16));border:1px solid var(--gold);
  color:var(--gold2);padding:10px 18px;border-radius:999px;font-size:.92rem;font-weight:600;cursor:pointer;font-family:inherit;transition:.2s}
.sm-geo:hover{background:linear-gradient(135deg,rgba(255,77,166,.28),rgba(226,29,122,.28))}
.sm-geo.loading{opacity:.6;pointer-events:none}
.sm-geo.loading .ico{animation:spin .8s linear infinite}
.sm-field{display:flex;flex-direction:column;gap:8px}
.sm-field>label{font-size:.82rem;color:var(--muted);font-weight:600;letter-spacing:.02em;text-transform:uppercase}
.sm-hint{text-transform:none;font-weight:400;letter-spacing:0;color:var(--muted);opacity:.8}
.sm-chips{display:flex;flex-wrap:wrap;gap:7px}
.sm-chips-wrap{max-height:148px;overflow-y:auto;padding-right:4px}
.schip{padding:7px 14px;border-radius:999px;border:1px solid var(--line);background:var(--card);
  color:var(--muted);font-size:.86rem;cursor:pointer;transition:.18s;font-family:inherit}
.schip:hover{border-color:var(--gold);color:var(--txt)}
.schip.on{background:linear-gradient(135deg,var(--gold2),var(--gold));color:#fff;border-color:transparent;font-weight:600}

/* ===== Loader del scroll infinito ===== */
.infinite-loader[hidden]{display:none}
.infinite-loader{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:30px;
  color:var(--muted);font-size:.92rem;min-height:40px}
.spin{width:18px;height:18px;border-radius:50%;border:2px solid var(--line);border-top-color:var(--gold);
  display:inline-block;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== Página de Planes ===== */
.planes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;max-width:840px;margin:0 auto}
.plan-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:20px;
  padding:30px 26px;display:flex;flex-direction:column;gap:20px}
.plan-vip{border-color:var(--gold);background:
  radial-gradient(120% 80% at 50% 0,rgba(226,29,122,.14),transparent 60%),var(--card);
  box-shadow:0 20px 60px -28px rgba(226,29,122,.6)}
.plan-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);white-space:nowrap;
  background:linear-gradient(135deg,var(--gold2),var(--gold));color:#fff;font-size:.74rem;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;padding:6px 16px;border-radius:999px;display:inline-flex;align-items:center;gap:6px}
.plan-badge .ico{width:.95em;height:.95em}
.plan-head{text-align:center;border-bottom:1px solid var(--line);padding-bottom:18px}
.plan-head h2{font-size:1.7rem}
.plan-tabs{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin:14px 0}
.plan-tab{padding:6px 13px;border-radius:999px;border:1px solid var(--line);background:var(--bg2);
  color:var(--muted);font-size:.8rem;cursor:pointer;font-family:inherit;transition:.18s}
.plan-tab:hover{border-color:var(--gold);color:var(--txt)}
.plan-tab.on{background:linear-gradient(135deg,var(--gold2),var(--gold));color:#fff;border-color:transparent;font-weight:600}
.plan-price{display:flex;align-items:baseline;justify-content:center;gap:6px;margin-top:6px}
.plan-amount{font-family:'Anton','Inter',sans-serif;font-size:2.6rem;line-height:1;color:var(--txt)}
.plan-vip .plan-amount{background:linear-gradient(135deg,var(--gold2),var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.plan-per{color:var(--muted);font-size:1rem}
.plan-save{color:var(--gold2);font-size:.85rem;margin-top:8px;min-height:1.2em}
.plan-feats{list-style:none;display:flex;flex-direction:column;gap:11px;flex:1}
.plan-feats li{display:flex;align-items:flex-start;gap:10px;font-size:.92rem;color:var(--txt)}
.plan-feats .ico{color:var(--gold);flex:none;margin-top:.18em;width:1.05em;height:1.05em}

.pago-box{max-width:840px;margin:38px auto 0;background:var(--card);border:1px solid var(--line);border-radius:20px;padding:28px 26px}
.pago-box h3{font-size:1.4rem;margin-bottom:18px;text-align:center}
.pago-steps{list-style:none;counter-reset:step;display:grid;gap:14px}
.pago-steps li{display:flex;align-items:flex-start;gap:14px;background:var(--bg2);border:1px solid var(--line);
  border-radius:14px;padding:14px 16px}
.pago-ico{flex:none;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,rgba(255,77,166,.18),rgba(226,29,122,.18));color:var(--gold2)}
.pago-ico .ico{width:1.2em;height:1.2em}
.pago-steps li>div{padding-top:4px;font-size:.95rem}
@media(max-width:620px){
  .planes-grid{grid-template-columns:1fr;max-width:420px}
}
.vip-upsell{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:18px;padding:12px 16px;
  border-radius:14px;border:1px solid var(--gold);font-size:.9rem;
  background:linear-gradient(135deg,rgba(255,77,166,.12),rgba(226,29,122,.12))}
.vip-upsell .ico{color:var(--gold2);flex:none}
.vip-upsell a{color:var(--gold2);font-weight:700;text-decoration:underline}

/* ===== Grid de tarjetas ===== */
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}
.section-head h2{font-size:1.7rem}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:20px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  position:relative;transition:.32s cubic-bezier(.2,.7,.2,1)}
.card:hover{transform:translateY(-6px);border-color:rgba(226,29,122,.5);box-shadow:var(--shadow)}
.card .ph{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--card2)}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:.5s}
.card:hover .ph img{transform:scale(1.07)}
.card .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(8,8,10,.92) 8%,transparent 52%)}
.card .toprow{position:absolute;top:9px;left:9px;right:9px;z-index:2;display:flex;align-items:flex-start;justify-content:space-between;gap:6px}
.card .badges{display:flex;gap:5px;flex-wrap:wrap;flex:1 1 auto;min-width:0}
.badge{font-size:.62rem;font-weight:700;padding:3px 7px;border-radius:999px;backdrop-filter:blur(6px);letter-spacing:.2px}
.card .price{font-size:.78rem;padding:4px 8px}
.badge-ver{background:rgba(39,192,138,.92);color:#04261a}
.badge-vid{background:rgba(224,67,107,.92);color:#fff}
.badge-lux{background:linear-gradient(135deg,var(--gold2),var(--gold));color:#fff}
.card .info{position:absolute;bottom:0;left:0;right:0;padding:14px;z-index:2}
.card .info .nm{font-weight:700;font-size:1.06rem;display:flex;align-items:center;gap:6px}
.card .info .nm small{font-weight:400;color:var(--gold2)}
.card .info .loc{color:var(--muted);font-size:.82rem;display:flex;align-items:center;gap:5px;margin-top:2px}
.card .info .desc{color:#cfcad4;font-size:.82rem;margin-top:7px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card .price{flex:0 0 auto;white-space:nowrap;background:rgba(10,10,12,.7);backdrop-filter:blur(6px);
  border:1px solid var(--line);padding:5px 11px;border-radius:10px;font-weight:700;font-size:.85rem;color:var(--gold2)}
.card .ts{font-size:.72rem;color:var(--muted);margin-top:6px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===== Banner publicar ===== */
.cta-band{background:linear-gradient(135deg,rgba(226,29,122,.14),rgba(224,67,107,.12));
  border:1px solid var(--line);border-radius:24px;padding:42px;text-align:center;margin:10px 0;position:relative;overflow:hidden}
.cta-band h2{font-size:2rem;margin-bottom:8px}
.cta-band p{color:var(--muted);max-width:560px;margin:0 auto 22px}
.free-tag{display:inline-block;background:var(--ok);color:#04261a;font-weight:700;padding:5px 14px;border-radius:999px;font-size:.82rem;margin-bottom:14px}

/* Franja de captación de modelos (home) */
.join{position:relative;overflow:hidden;background:linear-gradient(135deg,rgba(226,29,122,.18),rgba(255,77,166,.07) 55%,rgba(10,10,12,.25));border:1px solid var(--line);border-radius:24px;padding:48px 36px;text-align:center;margin:10px 0}
.join-inner{position:relative;z-index:1;max-width:860px;margin:0 auto}
.join .free-tag{display:inline-flex;align-items:center;gap:7px}
.join .free-tag .ico{width:16px;height:16px}
.join h2{font-size:2.15rem;line-height:1.08;margin:6px 0 12px}
.join p{color:var(--muted);max-width:640px;margin:0 auto 28px}
.join-perks{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px;margin:0 auto 30px;text-align:left;max-width:540px}
.join-perk{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:14px;padding:13px 16px}
.jp-ico{display:inline-grid;place-items:center;width:42px;height:42px;flex:0 0 42px;border-radius:11px;background:rgba(226,29,122,.15)}
.jp-ico .ico{width:22px;height:22px;color:var(--gold2)}
.join-perk strong{display:block;font-size:.97rem;font-weight:700}
.join-perk span{color:var(--muted);font-size:.82rem}
.join-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
@media(max-width:560px){.join{padding:34px 20px}.join h2{font-size:1.55rem}.join-cta{flex-direction:column}.join-cta .btn{width:100%;justify-content:center}}

/* ===== Perfil individual ===== */
.back-link{display:inline-flex;align-items:center;gap:7px;margin:24px 0 4px;padding:9px 16px;border:1px solid var(--line);
  border-radius:999px;color:var(--muted);font-size:.9rem;transition:.2s}
.back-link:hover{border-color:var(--gold);color:var(--txt);transform:translateX(-3px)}
.profile{display:grid;grid-template-columns:1.1fr .9fr;gap:30px;padding-top:14px}
.empty .big .ico{width:3rem;height:3rem;color:var(--gold);opacity:.7}
.sub span{display:inline-flex;align-items:center;gap:6px}
.badge{display:inline-flex;align-items:center;gap:4px}
.badge .ico{width:.85em;height:.85em}
.loc,.ts{display:flex;align-items:center;gap:5px}
.gallery .main{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);aspect-ratio:3/4;background:var(--card2)}
.gallery .main img,.gallery .main video{width:100%;height:100%;object-fit:cover}
.thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:10px}
.thumbs .th{aspect-ratio:1;border-radius:10px;overflow:hidden;border:2px solid transparent;cursor:pointer;position:relative;background:var(--card2)}
.thumbs .th.on{border-color:var(--gold)}
.thumbs .th img{width:100%;height:100%;object-fit:cover}
.thumbs .th .vico{position:absolute;inset:0;display:grid;place-items:center;background:rgba(0,0,0,.4);color:#fff;font-size:1.7rem}
.pdata h1{font-size:2.2rem}
.pdata .sub{color:var(--muted);margin-top:4px;display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0}
.tag{background:var(--card);border:1px solid var(--line);padding:6px 13px;border-radius:999px;font-size:.82rem;color:var(--muted);transition:.2s;cursor:pointer}
.tag::before{content:"#";color:var(--gold);font-weight:700;margin-right:1px}
.tag:hover{border-color:var(--gold);color:var(--txt)}
/* etiquetas del home como hashtags */
.etab-panel .chip::before{content:"#";color:var(--gold);font-weight:700;margin-right:1px;opacity:.85}
.attrs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin:20px 0}
.attrs div{background:var(--card);padding:13px 16px;font-size:.9rem}
.attrs div span{color:var(--muted);display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}
.desc-box{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px;margin:18px 0;white-space:pre-line}
.price-big{font-size:2rem;font-weight:800;color:var(--gold2);font-family:'Playfair Display',serif}

/* ===== Formularios / paneles ===== */
.panel-wrap{max-width:920px;margin:30px auto;padding:0 20px}
.auth-wrap{max-width:440px;margin:50px auto;padding:0 20px}
.box{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:28px}
.box h1,.box h2{margin-bottom:6px}
label{display:block;font-size:.86rem;color:var(--muted);margin:14px 0 6px}
input[type=text],input[type=email],input[type=password],input[type=number],input[type=tel],select,textarea{
  width:100%;background:var(--bg2);border:1px solid var(--line);color:var(--txt);
  padding:12px 14px;border-radius:11px;font-size:.95rem;font-family:inherit;transition:.2s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold)}
textarea{min-height:120px;resize:vertical}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.check{display:flex;gap:10px;align-items:flex-start;margin:14px 0;font-size:.88rem;color:var(--muted)}
.check input{width:18px;height:18px;margin-top:2px;accent-color:var(--gold)}
.alert{padding:13px 16px;border-radius:11px;margin-bottom:16px;font-size:.92rem}
.alert-bad{background:rgba(224,85,107,.14);border:1px solid var(--bad);color:#ffb3c0}
.alert-ok{background:rgba(39,192,138,.14);border:1px solid var(--ok);color:#9deccf}
.alert-warn{background:rgba(224,162,58,.14);border:1px solid var(--warn);color:#f0d3a0}

/* uploader */
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;margin-top:12px}
.media-item{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:var(--bg2)}
.media-item img,.media-item video{width:100%;height:100%;object-fit:cover}
.media-item .del{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.7);color:#fff;border:none;
  width:28px;height:28px;border-radius:8px;cursor:pointer;font-size:1rem}
.media-item .pin{position:absolute;bottom:6px;left:6px;background:var(--gold);color:#fff;font-size:.66rem;font-weight:700;padding:3px 7px;border-radius:6px}
.drop{border:2px dashed var(--line);border-radius:14px;padding:28px;text-align:center;color:var(--muted);cursor:pointer;transition:.2s}
.drop:hover{border-color:var(--gold);color:var(--txt)}

/* estado */
.status-pill{display:inline-block;padding:4px 12px;border-radius:999px;font-size:.78rem;font-weight:700}
.s-pendiente{background:rgba(224,162,58,.18);color:var(--warn)}
.s-aprobado{background:rgba(39,192,138,.18);color:var(--ok)}
.s-rechazado{background:rgba(224,85,107,.18);color:var(--bad)}
.s-pausado,.s-borrador{background:var(--card2);color:var(--muted)}

/* tabla admin */
.tbl{width:100%;border-collapse:collapse;font-size:.9rem}
.tbl th,.tbl td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line)}
.tbl th{color:var(--muted);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}
.tbl tr:hover td{background:var(--card)}
.mini{width:46px;height:60px;object-fit:cover;border-radius:8px}

/* ===== Footer ===== */
.ftr{border-top:1px solid var(--line);margin-top:50px;padding:40px 0 26px;background:var(--bg2)}
.ftr .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;margin-bottom:26px}
.ftr h4{font-family:inherit;font-size:.82rem;text-transform:uppercase;letter-spacing:1px;color:var(--gold);margin-bottom:12px}
.ftr a{display:block;color:var(--muted);font-size:.9rem;padding:4px 0;transition:.2s}
.ftr a:hover{color:var(--txt)}
.ftr .age{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--bad);color:var(--bad);
  font-weight:700;padding:6px 14px;border-radius:10px;font-size:.85rem;margin-bottom:14px}
.ftr .copy{border-top:1px solid var(--line);padding-top:18px;color:var(--muted);font-size:.82rem;text-align:center}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:34px}
.pagination a,.pagination span{padding:9px 15px;border-radius:10px;border:1px solid var(--line);color:var(--muted)}
.pagination a:hover{border-color:var(--gold);color:var(--txt)}
.pagination .cur{background:var(--gold);color:#fff;border-color:transparent;font-weight:700}

.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.empty .big{font-size:3rem;margin-bottom:10px}

/* ===== Panel de administración ===== */
body.admin{display:flex;min-height:100vh}
.adm-side{position:fixed;top:0;left:0;bottom:0;width:236px;background:var(--bg2);border-right:1px solid var(--line);
  padding:18px 12px;display:flex;flex-direction:column;z-index:80;transition:transform .3s;overflow-y:auto}
.adm-brand{font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;font-weight:800;font-size:1.15rem;color:#fff;
  padding:6px 10px 16px;letter-spacing:-.4px}
.adm-brand span{color:var(--gold);font-weight:600}
.adm-side nav{display:flex;flex-direction:column;gap:3px}
.adm-nav{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:10px;color:var(--muted);
  font-size:.93rem;transition:.18s;font-weight:500}
.adm-nav .ico{width:1.2em;height:1.2em;flex:none}
.adm-nav:hover{background:var(--card);color:var(--txt)}
.adm-nav.on{background:linear-gradient(135deg,rgba(226,29,122,.2),rgba(226,29,122,.05));color:var(--gold2);font-weight:700}
.adm-nav .pill{margin-left:auto;background:var(--fucsia);color:#fff;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:999px}
.adm-sep{height:1px;background:var(--line);margin:12px 6px}
.adm-side .muted-lbl{font-size:.68rem;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted);padding:6px 12px 4px;opacity:.7}
.adm-main{flex:1;margin-left:236px;min-width:0;display:flex;flex-direction:column}
.adm-top{position:sticky;top:0;z-index:60;display:flex;align-items:center;gap:14px;padding:15px 26px;
  background:rgba(10,10,12,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.adm-top h1{font-family:'Playfair Display',serif;font-size:1.45rem;line-height:1}
.adm-top .who{margin-left:auto;color:var(--muted);font-size:.85rem;display:flex;align-items:center;gap:12px;white-space:nowrap}
.adm-burger{display:none;background:none;border:none;color:var(--txt);cursor:pointer;padding:0}
.adm-burger .ico{width:1.5em;height:1.5em}
.adm-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:70}
.adm-backdrop.on{display:block}
.adm-content{padding:24px 26px 60px}
.adm-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:15px;margin-bottom:24px}
.adm-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px 20px;position:relative;
  overflow:hidden;transition:.2s}
.adm-card:hover{border-color:rgba(226,29,122,.45);transform:translateY(-3px);box-shadow:var(--shadow)}
.adm-card .k{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:.84rem;margin-bottom:10px}
.adm-card .k .ico{width:1.1em;height:1.1em;color:var(--gold)}
.adm-card .v{font-size:2rem;font-weight:800;font-family:'Playfair Display',serif;line-height:1}
.adm-card .v small{font-size:.9rem;color:var(--muted);font-family:'Inter',sans-serif;font-weight:500}
.adm-card.hot{border-color:var(--fucsia);background:linear-gradient(135deg,rgba(226,29,122,.14),var(--card))}
.adm-card.hot .k .ico{color:var(--fucsia2)}
.cardlink{position:absolute;inset:0;z-index:1}
.adm-grid2{display:grid;grid-template-columns:1.5fr 1fr;gap:18px;align-items:start}
.adm-panel{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.adm-panel .ph{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line)}
.adm-panel .ph h3{font-size:1.05rem}
.adm-panel .bd{padding:8px 0}
.adm-row{display:flex;align-items:center;gap:12px;padding:11px 20px;border-bottom:1px solid var(--line);transition:.15s}
.adm-row:last-child{border-bottom:none}
.adm-row:hover{background:var(--bg2)}
.adm-row img{width:44px;height:56px;object-fit:cover;border-radius:8px;flex:none;background:var(--card2)}
.adm-row .meta{min-width:0;flex:1}
.adm-row .meta b{display:block;font-size:.94rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adm-row .meta span{color:var(--muted);font-size:.8rem}
.adm-actions{display:flex;flex-wrap:wrap;gap:5px}
.adm-actions .btn{padding:6px 10px;font-size:.78rem}
.adm-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:18px}
.adm-toolbar form.search{flex:1;min-width:200px;display:flex;gap:8px}
.adm-toolbar .search input{flex:1}
.adm-empty{text-align:center;padding:50px 20px;color:var(--muted)}
.adm-empty .ico{width:2.6rem;height:2.6rem;color:var(--gold);opacity:.6;margin-bottom:8px}
.field-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.danger-zone{border:1px solid var(--bad);border-radius:14px;padding:18px;margin-top:8px;background:rgba(224,85,107,.05)}
.danger-zone h3{color:var(--bad);font-size:1rem;margin-bottom:6px}

@media(max-width:960px){
  .adm-side{transform:translateX(-100%);box-shadow:0 0 40px rgba(0,0,0,.6)}
  .adm-side.open{transform:none}
  .adm-main{margin-left:0}
  .adm-burger{display:block}
  .adm-grid2{grid-template-columns:1fr}
  .adm-content{padding:18px 16px 50px}
  .adm-top{padding:14px 16px}
}

/* ===== Age gate ===== */
.agegate{position:fixed;inset:0;z-index:999;background:rgba(6,6,8,.97);backdrop-filter:blur(8px);
  display:grid;place-items:center;padding:20px;text-align:center}
.agegate .box{max-width:480px}
.agegate h2{font-size:1.8rem;margin-bottom:10px}
.agegate .logo-ag{height:46px;margin:0 auto 18px;filter:invert(1) brightness(1.6)}

/* responsive */
@media(max-width:860px){
  .profile{grid-template-columns:1fr}
  .ftr .cols{grid-template-columns:1fr 1fr}
  .nav{position:absolute;top:calc(100% + 6px);right:12px;width:220px;flex-direction:column;align-items:stretch;
    background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:10px;gap:4px;
    box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(-8px);transition:.2s;z-index:60}
  .nav.open{opacity:1;visibility:visible;transform:none}
  .nav a{padding:12px}
  .nav .btn-fucsia{justify-content:center;margin-top:4px}
  .menu-tog{display:inline-flex;align-items:center}
  .hdr .bar{gap:10px}
  .city-switch{min-width:0}
  .city-switch .csel-btn{min-width:0;max-width:38vw}
  .row2,.row3{grid-template-columns:1fr}
  .searchbar{flex-direction:column;gap:8px;padding:10px}
  .searchbar input[type=text]{flex:0 0 auto;width:100%;border:1px solid var(--line);border-radius:10px}
  .searchbar select{flex:0 0 auto;width:100%;margin:0}
  .searchbar .csel{flex:0 0 auto;width:100%;margin:0}
  .searchbar .btn{flex:0 0 auto;width:100%;justify-content:center;padding:13px}
  .chips-scroll{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;padding-bottom:6px;margin-left:-20px;margin-right:-20px;padding-left:20px;padding-right:20px}
  .chips-scroll::-webkit-scrollbar{display:none}
  .chips-scroll .chip{flex:0 0 auto}
}
@media(max-width:520px){
  .wordmark{font-size:1.32rem}
  .wordmark span{display:none}
  .city-switch .csel-btn{max-width:30vw;font-size:.82rem;min-width:0;padding:8px 10px}
  .btn-search span{display:none}
  .btn-search{padding:9px 11px}
  .sm-box{padding:18px}
  .grid{grid-template-columns:repeat(auto-fill,minmax(46%,1fr));gap:12px}
  .ftr .cols{grid-template-columns:1fr}
  .attrs{grid-template-columns:1fr}
}

/* ===== Landing: publicar gratis ===== */
.lp-hero{padding:62px 0 42px}
.lp-tag{display:inline-flex;align-items:center;gap:7px;background:rgba(39,192,138,.14);color:var(--ok);
  border:1px solid rgba(39,192,138,.35);font-weight:700;font-size:.82rem;padding:7px 16px;border-radius:999px;letter-spacing:.4px}
.lp-tag .ico{width:1em;height:1em}
.lp-hero h1{margin-top:18px}
.lp-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:26px}
.lp-grants{list-style:none;display:flex;gap:10px 22px;justify-content:center;flex-wrap:wrap;margin-top:28px}
.lp-grants li{display:flex;align-items:center;gap:7px;color:var(--muted);font-size:.92rem;font-weight:500}
.lp-grants .ico{width:1.05em;height:1.05em;color:var(--ok)}

.lp-benefits{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.lp-bcard{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px 22px;transition:.25s}
.lp-bcard:hover{border-color:var(--gold);transform:translateY(-4px)}
.lp-bico{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:13px;
  background:linear-gradient(135deg,rgba(226,29,122,.22),rgba(255,77,166,.12));margin-bottom:14px}
.lp-bico .ico{width:24px;height:24px;color:var(--gold2)}
.lp-bcard h3{font-size:1.12rem;margin-bottom:8px;text-transform:none;font-family:'Inter',sans-serif;font-weight:700;letter-spacing:0}
.lp-bcard p{color:var(--muted);font-size:.92rem}

.lp-free{display:grid;grid-template-columns:1.3fr 1fr;gap:30px;align-items:center;background:var(--card);
  border:1px solid var(--line);border-radius:22px;padding:34px 32px}
.lp-free h2{font-size:1.9rem;margin:12px 0 10px}
.lp-free-feats{list-style:none;display:grid;gap:11px}
.lp-free-feats li{display:flex;align-items:center;gap:9px;font-weight:500}
.lp-free-feats>li .ico{color:var(--ok);flex:none}
@media(max-width:760px){.lp-free{grid-template-columns:1fr;padding:26px 22px}}

.lp-cities{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.lp-cities .chip .ico{width:.95em;height:.95em;color:var(--gold)}

.lp-faq{max-width:780px;margin:0 auto;display:grid;gap:12px}
.lp-faq-item{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.lp-faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:14px;cursor:pointer;
  padding:18px 20px;font-weight:600;list-style:none}
.lp-faq-item summary::-webkit-details-marker{display:none}
.lp-faq-x{flex:none;color:var(--gold);transition:transform .25s;transform:rotate(90deg)}
.lp-faq-x .ico{width:1.05em;height:1.05em}
.lp-faq-item[open] .lp-faq-x{transform:rotate(-90deg)}
.lp-faq-a{padding:0 20px 18px;color:var(--muted);font-size:.95rem}

/* ===== Botones rápidos del home (Activas / Cerca de mí / Nuevos) ===== */
.quick-filters{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:18px auto 0;max-width:840px;position:relative;z-index:2}
.quick-filters .qf{display:inline-flex;align-items:center;gap:9px;padding:10px 18px;border-radius:999px;
  background:var(--card);border:1px solid var(--line);color:var(--txt);font-size:.92rem;font-weight:600;
  cursor:pointer;font-family:inherit;transition:.22s;white-space:nowrap}
.quick-filters .qf:hover{border-color:var(--gold);color:#fff;transform:translateY(-2px);
  box-shadow:0 10px 26px -12px rgba(226,29,122,.55)}
.quick-filters .qf-ico{display:inline-grid;place-items:center;width:26px;height:26px;border-radius:8px;flex:none;
  background:linear-gradient(135deg,rgba(226,29,122,.28),rgba(255,77,166,.14))}
.quick-filters .qf-ico .ico{width:16px;height:16px;color:var(--gold2)}
.quick-filters .qf.loading{opacity:.6;pointer-events:none}
.quick-filters .qf.loading .qf-ico .ico{animation:qfpulse 1s ease-in-out infinite}
@keyframes qfpulse{0%,100%{opacity:1}50%{opacity:.35}}

/* ===== Sección Vincúlate (refuerzo del lado oferta) ===== */
.vinc-band .free-tag{display:inline-flex;align-items:center;gap:7px}
.vinc-band .free-tag .ico{width:15px;height:15px}
.vinc-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:6px}
@media(max-width:560px){.vinc-cta{flex-direction:column}.vinc-cta .btn{width:100%;justify-content:center}}

/* ===== Modal de perfil tipo Instagram ===== */
.pmodal{position:fixed;inset:0;z-index:120;display:none}
.pmodal.open{display:block}
.pm-backdrop{position:absolute;inset:0;background:rgba(6,6,9,.72);backdrop-filter:blur(8px);
  animation:pmFade .2s ease}
.pm-shell{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  padding:24px;pointer-events:none}
.pm-body{pointer-events:auto;width:100%;max-width:920px;max-height:90vh;overflow:hidden;
  background:var(--bg2);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);
  animation:pmPop .24s cubic-bezier(.2,.8,.25,1)}
@keyframes pmFade{from{opacity:0}to{opacity:1}}
@keyframes pmPop{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.pm-spin{display:grid;place-items:center;min-height:340px}

.pm-card{position:relative;display:grid;grid-template-columns:1fr 1fr;max-height:90vh}
.pm-close{position:absolute;top:12px;right:12px;z-index:3;width:40px;height:40px;border-radius:999px;
  display:grid;place-items:center;background:rgba(10,10,12,.6);border:1px solid var(--line);color:#fff;
  cursor:pointer;transition:.2s;backdrop-filter:blur(6px)}
.pm-close:hover{background:var(--gold);border-color:transparent}
.pm-close .ico{width:20px;height:20px}

/* Galería */
.pm-gallery{background:var(--card2);padding:14px;overflow-y:auto;max-height:90vh}
.pm-main{border-radius:14px;overflow:hidden;border:1px solid var(--line);aspect-ratio:3/4;background:var(--bg)}
.pm-main img,.pm-main video{width:100%;height:100%;object-fit:cover;display:block}
.pm-thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:7px;margin-top:10px}
.pm-th{aspect-ratio:1;border-radius:9px;overflow:hidden;border:2px solid transparent;cursor:pointer;
  position:relative;background:var(--bg);padding:0}
.pm-th.on{border-color:var(--gold)}
.pm-th img{width:100%;height:100%;object-fit:cover}
.pm-vico{position:absolute;inset:0;display:grid;place-items:center;background:rgba(0,0,0,.42);color:#fff}
.pm-vico .ico{width:1.5rem;height:1.5rem}

/* Datos */
.pm-data{padding:30px 28px 26px;overflow-y:auto;max-height:90vh}
.pm-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.pm-name{font-size:2rem;line-height:1.05}
.pm-name small{font-family:'Inter',sans-serif;font-weight:600;font-size:1.1rem;color:var(--muted);text-transform:none}
.pm-sub{color:var(--muted);margin-top:6px;display:flex;gap:14px;flex-wrap:wrap;align-items:center;font-size:.92rem}
.pm-sub span{display:inline-flex;align-items:center;gap:6px}
.pm-sub .ico{width:1em;height:1em;color:var(--gold)}
.pm-tags{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0}
.pm-price{margin:16px 0}
.pm-price .muted{font-size:.78rem;display:block}
.pm-actions{display:grid;gap:10px;margin:18px 0}
.pm-meta{font-size:.8rem;display:flex;align-items:center;gap:6px;margin-top:14px}
.pm-meta .ico{width:1em;height:1em}
.pm-full{display:inline-flex;align-items:center;gap:7px;margin-top:14px;color:var(--gold2);font-weight:600;font-size:.92rem}
.pm-full:hover{color:var(--gold)}
.pm-full .ico{width:1.05em;height:1.05em}

/* Vacío / 404 dentro del modal */
.pm-empty{padding:60px 30px;text-align:center;color:var(--muted)}
.pm-empty-ico{display:inline-grid;place-items:center;margin-bottom:10px}
.pm-empty-ico .ico{width:2.6rem;height:2.6rem;color:var(--gold);opacity:.7}
.pm-empty h2{color:var(--txt);font-size:1.5rem;margin-bottom:8px}

@media(max-width:760px){
  .pm-shell{padding:0;align-items:stretch}
  .pm-body{max-width:100%;max-height:100vh;height:100vh;border-radius:0;border:none}
  .pm-card{grid-template-columns:1fr;max-height:100vh;overflow-y:auto}
  .pm-gallery,.pm-data{max-height:none;overflow:visible}
  .pm-gallery{padding:0}
  .pm-main{border-radius:0;border:none;aspect-ratio:4/5}
  .pm-thumbs{padding:10px 12px 0}
  .pm-data{padding:22px 20px 32px}
  .pm-name{font-size:1.7rem}
}

/* ===== Barra de carga entre páginas + fade-in ===== */
#pageBar{position:fixed;top:0;left:0;height:3px;width:0;z-index:9999;
  background:linear-gradient(90deg,var(--gold2),var(--gold));box-shadow:0 0 12px var(--gold);
  opacity:0;transition:width .4s ease,opacity .35s;pointer-events:none}
#pageBar.go{opacity:1;width:88%}
#pageBar.done{opacity:1;width:100%;transition:width .25s ease,opacity .3s .15s}
@media(prefers-reduced-motion:no-preference){
  body{animation:pagefade .38s ease}
}
@keyframes pagefade{from{opacity:0}to{opacity:1}}

/* link destacado del menú (captación de modelos) */
.nav a.nav-hot{color:var(--ok);font-weight:700}
.nav a.nav-hot:hover{color:#3fe0a5;background:rgba(39,192,138,.12)}
