
:root {
  --bg: #07111d;
  --bg-2: #06101b;
  --panel: rgba(8, 18, 31, 0.78);
  --panel-2: rgba(10, 22, 37, 0.86);
  --panel-soft: rgba(255,255,255,0.035);
  --text: #f6fbff;
  --muted: rgba(226, 236, 248, 0.76);
  --muted-2: rgba(226, 236, 248, 0.62);
  --line: rgba(141, 199, 255, 0.14);
  --line-2: rgba(97, 236, 255, 0.18);
  --aqua: #61ecff;
  --cyan: #4ca7ff;
  --green: #8dff74;
  --shadow: 0 18px 42px rgba(0, 0, 0, 0.22);
  --radius: 28px;
  --container: min(1120px, calc(100% - 32px));
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 16% 12%, rgba(76, 167, 255, 0.10), transparent 28%),
    radial-gradient(circle at 82% 10%, rgba(141, 255, 116, 0.05), transparent 18%),
    linear-gradient(180deg, #040b14 0%, #06101b 54%, #07111d 100%);
  min-height: 100vh;
  overflow-x: hidden;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 88% 20%, rgba(255, 173, 89, 0.06), transparent 16%),
    radial-gradient(circle at 12% 84%, rgba(97, 236, 255, 0.04), transparent 18%);
  z-index: -1;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
.container { width: var(--container); margin: 0 auto; }
.nowrap { white-space: nowrap; }
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 40;
  background: linear-gradient(90deg, rgba(4, 9, 16, 0.94) 0%, rgba(11, 18, 30, 0.92) 50%, rgba(4, 9, 16, 0.94) 100%);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(160, 211, 255, 0.10);
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.20);
  transition: background 0.28s ease, border-color 0.28s ease, box-shadow 0.28s ease;
}
.site-header.scrolled {
  background: linear-gradient(90deg, rgba(3, 8, 15, 0.98) 0%, rgba(8, 14, 24, 0.97) 50%, rgba(3, 8, 15, 0.98) 100%);
  border-bottom-color: rgba(160, 211, 255, 0.14);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.24);
}
.header-inner {
  width: var(--container);
  margin: 0 auto;
  min-height: 74px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.brand img {
  width: clamp(60px, 9vw, 76px);
  border-radius: 16px;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.18);
  flex: 0 0 auto;
}
.brand-text {
  display: inline-block;
  color: rgba(247, 251, 255, 0.94);
  font-size: clamp(0.96rem, 2vw, 1.08rem);
  font-weight: 650;
  letter-spacing: -0.025em;
  line-height: 1.05;
  white-space: nowrap;
  text-shadow: 0 4px 14px rgba(0, 0, 0, 0.18);
}
.menu-toggle {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(131, 188, 255, 0.16);
  border-radius: 14px;
  background: rgba(4, 12, 22, 0.64);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: var(--text);
  cursor: pointer;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.12);
  transition: transform 0.22s ease, border-color 0.22s ease, background 0.22s ease;
}
.menu-toggle:hover,
.menu-toggle:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(97, 236, 255, 0.28);
  background: rgba(8, 18, 31, 0.84);
  outline: none;
}
.menu-toggle svg { width: 22px; height: 22px; }
.mobile-menu {
  position: fixed;
  top: 88px;
  right: 16px;
  left: 16px;
  padding: 14px;
  border-radius: 24px;
  background: rgba(8, 17, 30, 0.9);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border: 1px solid rgba(135, 193, 255, 0.16);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.28);
  display: grid;
  gap: 8px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: opacity 0.22s ease, transform 0.22s ease, visibility 0.22s ease;
  z-index: 35;
}
.mobile-menu.open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.mobile-menu a {
  padding: 14px 16px;
  border-radius: 16px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid transparent;
  font-size: 0.98rem;
  font-weight: 600;
  transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}
.mobile-menu a:hover,
.mobile-menu a:focus-visible,
.mobile-menu a.is-active {
  background: rgba(97, 236, 255, 0.06);
  border-color: rgba(97, 236, 255, 0.16);
  transform: translateX(2px);
  outline: none;
}
.site-main {
  padding-top: 98px;
  padding-bottom: 72px;
}
.page-hero {
  padding: 14px 0 16px;
}
.page-hero-shell {
  position: relative;
  padding: 22px;
  border-radius: 30px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255,255,255,0.015)),
    rgba(8, 18, 31, 0.70);
  border: 1px solid rgba(151, 211, 255, 0.12);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.18), inset 0 1px 0 rgba(255,255,255,0.02);
  overflow: hidden;
}
.page-hero-shell::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, rgba(97, 236, 255, 0.24), rgba(141, 255, 116, 0.08), transparent 90%);
}
.page-hero-shell::after {
  content: "";
  position: absolute;
  top: -48px;
  right: -32px;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(97, 236, 255, 0.11) 0%, rgba(97,236,255,0) 72%);
}
.page-hero-grid {
  display: grid;
  gap: 18px;
  position: relative;
  z-index: 1;
}
.kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(5, 17, 28, 0.26);
  border: 1px solid rgba(170, 218, 255, 0.14);
  color: rgba(241, 248, 255, 0.88);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  font-weight: 700;
  text-transform: uppercase;
}
.kicker::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--aqua), var(--green));
  box-shadow: 0 0 12px rgba(97,236,255,0.8);
}
.page-hero h1 {
  margin: 0;
  font-family: "Outfit", Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: clamp(2rem, 8vw, 4rem);
  line-height: 0.98;
  letter-spacing: -0.045em;
  font-weight: 500;
  text-wrap: balance;
  max-width: 11ch;
}
.page-hero p {
  margin: 12px 0 0;
  max-width: 34rem;
  color: rgba(247, 251, 255, 0.74);
  font-size: clamp(0.98rem, 2.8vw, 1.05rem);
  line-height: 1.72;
}
.hero-accent {
  width: min(132px, 32vw);
  height: 3px;
  border-radius: 999px;
  margin: 16px 0 0;
  background: linear-gradient(90deg, var(--cyan), var(--aqua), var(--green));
  box-shadow: 0 0 16px rgba(97, 236, 255, 0.22);
}
.page-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 22px;
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 52px;
  padding: 0 18px;
  border-radius: 18px;
  font-weight: 700;
  font-size: 0.96rem;
  border: 1px solid transparent;
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease, background 0.22s ease;
}
.btn:hover,
.btn:focus-visible {
  transform: translateY(-1px);
  outline: none;
}
.btn-primary {
  color: #031019;
  background: linear-gradient(135deg, #8ffff8 0%, #62d9ff 44%, #99ff7e 100%);
  border-color: rgba(255, 255, 255, 0.18);
  box-shadow: 0 14px 28px rgba(10, 20, 35, 0.22), 0 0 18px rgba(97, 236, 255, 0.18);
}
.btn-secondary {
  color: var(--text);
  background: rgba(7, 18, 31, 0.36);
  border-color: rgba(171, 221, 255, 0.16);
  box-shadow: 0 14px 28px rgba(0,0,0,0.14);
}
.btn-secondary:hover,
.btn-secondary:focus-visible {
  border-color: rgba(97, 236, 255, 0.24);
  background: rgba(7,18,31,0.46);
}
.hero-aside {
  display: grid;
  gap: 12px;
}
.info-card,
.notice-card,
.panel,
.legal-card,
.listing-card,
.price-card {
  position: relative;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.016)), rgba(8,18,31,0.72);
  border: 1px solid rgba(151, 211, 255, 0.12);
  box-shadow: 0 18px 36px rgba(0,0,0,0.18), inset 0 1px 0 rgba(255,255,255,0.02);
}
.info-card,
.notice-card,
.panel,
.legal-card,
.price-card { padding: 18px; }
.info-card strong,
.notice-card strong,
.panel strong,
.legal-card strong { display: block; font-size: 1rem; margin-bottom: 6px; }
.info-card p,
.notice-card p,
.panel p,
.legal-card p { margin: 0; color: var(--muted); line-height: 1.55; }
.notice-stack,
.stack { display: grid; gap: 12px; }
.notice-card.strong {
  background: linear-gradient(180deg, rgba(84, 240, 255, 0.10), rgba(84,240,255,0.02)), rgba(8,18,31,0.74);
}
.notice-card.warn {
  background: linear-gradient(180deg, rgba(255, 180, 92, 0.10), rgba(255,180,92,0.02)), rgba(8,18,31,0.74);
}
.section { padding-top: 14px; }
.section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}
.section-head h2 {
  margin: 0;
  font-size: clamp(1.3rem, 4vw, 2rem);
  line-height: 1.05;
  letter-spacing: -0.04em;
}
.section-head p {
  margin: 8px 0 0;
  color: rgba(199, 212, 229, 0.82);
  font-size: 0.96rem;
  line-height: 1.55;
}
.section-link {
  color: #dffbff;
  font-weight: 700;
  white-space: nowrap;
}
.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.filter-chip,
.meta li,
.pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
}
.filter-chip,
.meta li {
  background: rgba(7, 18, 31, 0.42);
  border: 1px solid rgba(171, 221, 255, 0.12);
  color: rgba(233, 243, 251, 0.86);
}
.pill {
  background: rgba(97, 236, 255, 0.08);
  border: 1px solid rgba(97, 236, 255, 0.12);
  color: #dffbff;
}
.pill.lime { background: rgba(141, 255, 116, 0.12); color: #ddffcf; border-color: rgba(141,255,116,0.18); }
.pill.green { background: rgba(76, 167, 255, 0.10); color: #d8ebff; border-color: rgba(76,167,255,0.16); }
.grid-3,
.legal-grid,
.pricing-grid,
.form-layout { display: grid; gap: 18px; }
.listing-card {
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 0;
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}
.listing-card:hover,
.listing-card:focus-within {
  transform: translateY(-3px);
  border-color: rgba(97, 236, 255, 0.18);
  box-shadow: 0 22px 42px rgba(0,0,0,0.22), inset 0 1px 0 rgba(255,255,255,0.03);
}
.listing-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 12px; }
.listing-card h3,
.price-card h3 { margin: 0 0 10px; font-size: 1.22rem; line-height: 1.08; letter-spacing: -0.03em; }
.listing-card p,
.price-card p { margin: 0; color: rgba(199,212,229,0.88); font-size: 0.97rem; line-height: 1.62; }
.meta { list-style: none; padding: 0; margin: 0 0 12px; display: flex; flex-wrap: wrap; gap: 8px; }
.list-actions,
.mini-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.chip-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 14px;
  background: rgba(7, 18, 31, 0.42);
  border: 1px solid rgba(171,221,255,0.12);
  color: #e7f7ff;
  font-size: 0.92rem;
  font-weight: 700;
}
.chip-link:hover,
.chip-link:focus-visible { border-color: rgba(97,236,255,0.22); outline: none; }
.icon-badge {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 15px;
  background: linear-gradient(180deg, rgba(12, 28, 46, 0.92), rgba(8, 19, 33, 0.84));
  border: 1px solid rgba(135, 193, 255, 0.14);
  color: var(--aqua);
  box-shadow: inset 0 0 24px rgba(97, 236, 255, 0.05);
}
.icon-badge svg { width: 20px; height: 20px; }
.panel h3,
.legal-card h3,
.price-card .price-amount { margin: 0; }
.form-layout { gap: 18px; }
.form-card { padding: 20px; }
.form-grid { display: grid; gap: 14px; }
.field { display: grid; gap: 8px; }
.field label { font-size: 0.9rem; font-weight: 700; color: rgba(247,251,255,0.92); }
.field input,
.field select,
.field textarea {
  width: 100%;
  border: 1px solid rgba(171, 221, 255, 0.14);
  border-radius: 18px;
  background: rgba(4, 12, 22, 0.66);
  color: var(--text);
  padding: 14px 15px;
  font: inherit;
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.02);
}
.field input::placeholder,
.field textarea::placeholder { color: rgba(226,236,248,0.42); }
.field textarea { min-height: 128px; resize: vertical; }
.field input:focus,
.field select:focus,
.field textarea:focus {
  border-color: rgba(97,236,255,0.28);
  box-shadow: 0 0 0 3px rgba(97,236,255,0.08);
}
.help-inline { margin: 0; color: rgba(226,236,248,0.62); font-size: 0.89rem; line-height: 1.5; }
.checkbox-line {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  color: rgba(226,236,248,0.76);
  font-size: 0.92rem;
  line-height: 1.5;
}
.checkbox-line input { margin-top: 4px; accent-color: #61ecff; }
.process-row,
.stat-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 12px; }
.stat-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(7, 18, 31, 0.42);
  border: 1px solid rgba(171,221,255,0.12);
  color: rgba(233,243,251,0.86);
  font-size: 0.82rem;
  font-weight: 700;
}
.pricing-grid { margin-top: 14px; }
.price-card { padding: 20px; }
.price-card.featured {
  border-color: rgba(97, 236, 255, 0.22);
  box-shadow: 0 22px 44px rgba(0,0,0,0.22), 0 0 24px rgba(97,236,255,0.08);
}
.price-amount {
  margin: 12px 0 8px;
  font-size: clamp(1.8rem, 6vw, 2.3rem);
  font-family: "Outfit", Inter, sans-serif;
  line-height: 1;
  letter-spacing: -0.045em;
}
.price-card p { max-width: 24ch; }
.legal-grid { margin-bottom: 18px; }
.legal-card { padding: 20px; }
.prose-card {
  padding: 22px;
}
.prose-card h2 {
  margin: 0 0 14px;
  font-size: clamp(1.38rem, 4.6vw, 2.15rem);
  line-height: 1.05;
  letter-spacing: -0.045em;
}
.prose-card h3 {
  margin: 20px 0 10px;
  font-size: 1.04rem;
  line-height: 1.25;
}
.prose-card p,
.prose-card li {
  color: rgba(226,236,248,0.78);
  line-height: 1.72;
  font-size: 0.97rem;
}
.prose-card ul { margin: 0; padding-left: 20px; }
.site-footer {
  border-top: 1px solid rgba(135, 193, 255, 0.08);
  padding: 18px 0 30px;
}
.footer-inner {
  width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
  color: rgba(219, 234, 249, 0.64);
  font-size: 0.9rem;
}
.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.footer-links a { color: rgba(232,246,255,0.9); }
.footer-note {
  margin: 0;
  color: rgba(219,234,249,0.58);
  line-height: 1.62;
}
@media (min-width: 700px) {
  .header-inner { min-height: 78px; }
  .mobile-menu { left: auto; width: 320px; }
  .page-hero-shell { padding: 28px; }
  .page-hero-grid { grid-template-columns: minmax(0, 1.25fr) minmax(250px, 0.75fr); align-items: end; }
  .grid-3,
  .legal-grid,
  .pricing-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .form-layout { grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr); align-items: start; }
  .footer-inner { flex-direction: row; justify-content: space-between; align-items: center; }
}
@media (max-width: 520px) {
  .site-main { padding-top: 92px; }
  .page-hero-shell { padding: 20px; border-radius: 26px; }
  .page-hero h1 { font-size: clamp(1.64rem, 10.2vw, 2.8rem); line-height: 0.98; max-width: 9.8ch; }
  .page-hero p { font-size: 0.96rem; }
  .btn { width: 100%; }
  .list-actions .chip-link { flex: 1 1 0; }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition: none !important; animation: none !important; }
}


.search-strip {
  padding: 10px 0 4px;
}
.search-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  padding: 10px;
  border-radius: 22px;
  background: rgba(19, 45, 72, 0.82);
  border: 1px solid rgba(190, 229, 255, 0.28);
  box-shadow: 0 18px 36px rgba(0,0,0,0.14), 0 0 0 1px rgba(255,255,255,0.04);
}
.search-form input,
.search-form select {
  min-height: 50px;
  width: 100%;
  padding: 0 16px;
  border-radius: 14px;
  border: 1px solid rgba(198, 234, 255, 0.34);
  background: rgba(235, 249, 255, 0.10);
  color: var(--text);
  font: inherit;
}
.search-form button,
.inline-btn {
  min-height: 50px;
  padding: 0 18px;
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: 14px;
  background: linear-gradient(135deg, #8ffff8 0%, #62d9ff 44%, #99ff7e 100%);
  color: #031019;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 12px 24px rgba(10,20,35,0.18);
}
.search-help {
  margin: 12px 0 0;
  color: var(--muted-2);
  font-size: 0.93rem;
}
.services-grid,
.thanks-grid,
.faq-grid,
.rules-grid {
  display: grid;
  gap: 18px;
}
.services-grid { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.service-card {
  position: relative;
  padding: 22px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.016)), rgba(8,18,31,0.72);
  border: 1px solid rgba(151, 211, 255, 0.12);
  box-shadow: 0 18px 36px rgba(0,0,0,0.18), inset 0 1px 0 rgba(255,255,255,0.02);
}
.service-card .service-top,
.listing-top { display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap; }
.service-card h3 { margin: 14px 0 8px; font-size: 1.3rem; line-height:1.05; letter-spacing:-0.03em; }
.offer-title { font-weight: 800; }
.offer-trabajo { color: #9fe8ff; }
.offer-personal { color: #9dffb3; }
.offer-profesional { color: #ffd38a; }
.listing-owner { margin: 8px 0 12px; color: #eaf8ff; font-size: 0.98rem; }
.service-card p,
.muted { color: var(--muted); }
.service-price {
  display:inline-flex; align-items:center; gap:8px; margin-top:10px; margin-bottom:14px;
  font-weight:700; color:#eaf8ff;
}
.service-list,
.check-list,
.faq-list { margin:0; padding-left: 18px; color: var(--muted); line-height: 1.65; }
.service-actions { display:flex; flex-wrap:wrap; gap:10px; margin-top: 18px; }
.mini-note { margin-top: 12px; color: var(--muted-2); font-size: 0.9rem; line-height:1.55; }
.steps-grid { display:grid; gap:14px; grid-template-columns:repeat(1,minmax(0,1fr)); }
.step-card {
  padding: 18px; border-radius: 24px; background: rgba(8,18,31,0.56); border:1px solid rgba(151,211,255,0.1);
  box-shadow: 0 14px 28px rgba(0,0,0,0.12);
}
.step-number {
  display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px; border-radius:12px;
  background: linear-gradient(135deg, rgba(97,236,255,0.18), rgba(141,255,116,0.14)); color: var(--text); font-weight:700; margin-bottom: 10px;
}
.note-bar {
  padding: 16px 18px; border-radius: 22px; background: rgba(8,18,31,0.56); border:1px solid rgba(151,211,255,0.1);
  color: var(--muted); line-height:1.62;
}
.faq-card,
.rule-card,
.thanks-card {
  padding: 18px; border-radius: 24px; background: rgba(8,18,31,0.62); border:1px solid rgba(151,211,255,0.1);
  box-shadow: 0 14px 28px rgba(0,0,0,0.12);
}
.thanks-card h2,
.faq-card h3,
.rule-card h3 { margin-top:0; }
.center-hero .page-hero-grid { align-items:center; }
.center-hero .page-hero p { max-width: 38rem; }
.cta-stack { display:grid; gap:12px; margin-top:20px; }
.result-count { color: var(--muted-2); font-size: 0.94rem; margin: 10px 0 0; }
.hidden-card { display:none !important; }
.list-actions { display:flex; flex-wrap:wrap; gap:10px; margin-top:16px; }
.chip-link {
  display:inline-flex; align-items:center; justify-content:center; min-height:40px; padding:0 14px;
  border-radius:999px; background: rgba(7,18,31,0.48); border:1px solid rgba(151,211,255,0.12); font-weight:600; font-size:0.92rem;
}
.chip-link:hover, .chip-link:focus-visible { border-color: rgba(97,236,255,0.24); outline:none; }
.footer-brand { color: rgba(247,251,255,0.88); font-weight: 700; }
.site-footer .footer-inner { align-items:flex-start; }
@media (min-width: 760px) {
  .services-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .steps-grid, .thanks-grid, .faq-grid, .rules-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .search-form { grid-template-columns: 1fr; }
}


.contact-line {
  margin-top: 12px !important;
  color: rgba(234, 246, 255, 0.82) !important;
  font-size: 0.92rem !important;
}
.empty-state {
  padding: 22px;
  border-radius: 26px;
  background: rgba(8,18,31,0.58);
  border: 1px solid rgba(151,211,255,0.10);
  color: var(--muted);
  line-height: 1.65;
}
.empty-state strong {
  display: block;
  margin-bottom: 8px;
  color: rgba(247,251,255,0.92);
  font-size: 1.02rem;
}


/* refined listing cards */
.listing-card-pro {
  padding: 26px 24px 22px;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(10,20,38,0.96), rgba(6,14,28,0.98)),
    radial-gradient(circle at top right, rgba(93, 169, 255, 0.08), transparent 35%);
  border: 1px solid rgba(115, 154, 212, 0.22);
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.28);
}

.listing-title {
  margin: 6px 0 12px;
  font-size: clamp(1.65rem, 2.1vw, 2.05rem);
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #f3f8ff;
}
.listing-subline {
  margin: 0 0 16px;
  font-size: 0.98rem;
  color: rgba(232, 241, 255, 0.9);
}
.info-stack { display: grid; gap: 12px; margin: 0 0 18px; }
.info-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  min-height: 54px;
  padding: 14px 18px;
  border-radius: 18px;
  background: rgba(12, 25, 45, 0.78);
  border: 1px solid rgba(96, 128, 179, 0.18);
}
.info-label {
  font-size: 0.92rem;
  font-weight: 700;
  color: #b9cbe3;
  white-space: nowrap;
}
.info-value {
  font-size: 1rem;
  font-weight: 700;
  color: #f3f8ff;
  text-align: right;
}
.listing-description {
  margin: 0 0 18px;
  font-size: 1rem;
  line-height: 1.7;
  color: rgba(230, 239, 250, 0.9);
}
.primary-contact-btn { min-width: 160px; justify-content: center; font-weight: 800; }
.list-actions { display: flex; gap: 12px; margin-top: 8px; }
.offer-title { font-weight: 800; letter-spacing: -0.02em; }
.offer-trabajo { color: #9fe8ff; }
.offer-personal { color: #9dffb3; }
.offer-profesional { color: #ffd38a; }
@media (max-width: 768px) {
  .listing-card-pro { padding: 22px 18px 20px; border-radius: 24px; }
  .info-row { flex-direction: column; align-items: flex-start; gap: 6px; min-height: auto; }
  .info-value { text-align: left; }
  .primary-contact-btn { width: 100%; }
  .list-actions { flex-direction: column; }
}


.top-home-link {
  padding: 0 0 12px;
}
.top-home-link .section-link {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
}
.search-form input::placeholder {
  color: rgba(238, 249, 255, 0.72);
}
.search-form input:focus {
  border-color: rgba(97,236,255,0.42);
  background: rgba(235,249,255,0.14);
  outline: none;
}
@media (max-width: 640px) {
  .search-form {
    background: rgba(26, 56, 86, 0.92);
    border-color: rgba(190, 229, 255, 0.36);
  }
}


/* v6 simple mobile page refinements */
@media (max-width: 520px) {
  .page-actions { margin-top: 18px; }
  .hero-aside { gap: 10px; }
  .info-card,
  .notice-card { padding: 14px; border-radius: 22px; }
  .info-card strong,
  .notice-card strong { font-size: 0.96rem; margin-bottom: 4px; }
  .info-card p,
  .notice-card p { font-size: 0.92rem; line-height: 1.45; }
  .search-form input { font-size: 0.95rem; }
}


/* Ajuste v10: publicar con tarjetas uniformes y categoría Sabor Latino */
.publish-grid { align-items: stretch; }
.publish-card { display: flex; flex-direction: column; min-height: 315px; }
.publish-card .service-actions { margin-top: auto; }
.offer-comida { color: #ffcb70; }
.offer-evento { color: #caa6ff; }
.offer-oferta { color: #ff87c5; }
.sabor-card {
  border-color: rgba(255, 190, 88, 0.22);
  background:
    radial-gradient(circle at 85% 8%, rgba(255, 142, 67, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.015)),
    rgba(8,18,31,0.74);
}
@media (min-width: 1040px) { .publish-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }


/* v11: tarjetas de Publicar más simples, iguales y fáciles desde celular */
.publish-grid {
  align-items: stretch;
}
.publish-card {
  min-height: 245px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  padding: 22px;
}
.publish-card h3 {
  margin: 0;
  min-height: 2.35em;
  font-size: clamp(1.12rem, 2vw, 1.28rem);
  line-height: 1.12;
}
.publish-card p {
  margin: 0;
  min-height: 3.1em;
  line-height: 1.45;
}
.publish-card .pill {
  margin-top: auto;
}
.publish-card .service-actions {
  width: 100%;
  margin-top: 8px;
}
.publish-card .service-actions .btn {
  width: 100%;
  min-height: 50px;
}
.publish-icon {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.7rem;
  background: linear-gradient(145deg, rgba(97,236,255,0.22), rgba(141,255,116,0.16));
  border: 1px solid rgba(181,240,255,0.20);
  box-shadow: inset 0 2px 0 rgba(255,255,255,0.10), 0 14px 28px rgba(0,0,0,0.18);
}
.publish-card-rapido .publish-icon { background: linear-gradient(145deg, rgba(77,255,172,0.24), rgba(0,170,115,0.18)); }
.publish-card-personal .publish-icon { background: linear-gradient(145deg, rgba(77,255,203,0.24), rgba(0,170,120,0.18)); }
.publish-card-profesional .publish-icon { background: linear-gradient(145deg, rgba(69,195,255,0.24), rgba(0,112,230,0.18)); }
.publish-card-evento .publish-icon { background: linear-gradient(145deg, rgba(193,124,255,0.26), rgba(103,61,240,0.20)); }
.publish-card-oferta .publish-icon { background: linear-gradient(145deg, rgba(255,97,178,0.26), rgba(205,35,112,0.20)); }
.publish-card-comida .publish-icon { background: linear-gradient(145deg, rgba(255,205,92,0.30), rgba(244,108,34,0.22)); }
@media (min-width: 1040px) {
  .publish-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 520px) {
  .publish-card { min-height: 220px; }
  .publish-card h3 { min-height: auto; }
  .publish-card p { min-height: auto; }
}

/* v11: páginas de listado más rápidas de leer */
.page-hero .page-actions .btn-primary {
  min-width: 190px;
}
@media (max-width: 640px) {
  .page-hero-shell { padding: 18px; }
  .page-hero-grid { gap: 14px; }
  .page-hero h1 { font-size: clamp(2.3rem, 14vw, 4.2rem); }
  .page-hero p { font-size: 1rem; line-height: 1.55; }
  .hero-aside { display: grid; }
  .hero-aside .info-card { order: 1; }
  .hero-aside .notice-card.strong { order: 2; }
  .hero-aside .notice-card.warn { order: 3; }
}

/* v11: estilos preparados para Eventos y Ofertas cuando existan datos */
.listing-card-pro[data-type="evento"],
.listing-card-pro[data-type="oferta"],
.listing-card-pro[data-type="comida"] {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: start;
}
.listing-date-box,
.listing-icon-box {
  width: 76px;
  min-height: 76px;
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #f7fbff;
  background: linear-gradient(145deg, rgba(97,236,255,0.22), rgba(76,167,255,0.16));
  border: 1px solid rgba(151,211,255,0.16);
  box-shadow: inset 0 2px 0 rgba(255,255,255,0.08), 0 14px 26px rgba(0,0,0,0.18);
}
.listing-date-day { font-size: 1.55rem; font-weight: 850; line-height: 1; }
.listing-date-month { font-size: 0.78rem; font-weight: 800; letter-spacing: 0.04em; text-transform: uppercase; margin-top: 5px; }
.listing-icon-box { font-size: 2rem; }
.listing-content-main { min-width: 0; }
.listing-card-pro[data-type="oferta"] .listing-icon-box { background: linear-gradient(145deg, rgba(255,97,178,0.24), rgba(205,35,112,0.18)); }
.listing-card-pro[data-type="comida"] .listing-icon-box { background: linear-gradient(145deg, rgba(255,205,92,0.30), rgba(244,108,34,0.22)); }
@media (max-width: 520px) {
  .listing-card-pro[data-type="evento"],
  .listing-card-pro[data-type="oferta"],
  .listing-card-pro[data-type="comida"] {
    grid-template-columns: 1fr;
  }
}

/* v17 premium listing cards: mobile-first, consistent, category-colored */
.services-grid,
.grid-3 {
  align-items: stretch;
  grid-auto-rows: 1fr;
}
@media (min-width: 900px) {
  .services-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1180px) {
  .services-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.listing-card-pro {
  --cat: #61ecff;
  --cat-2: #1e86ff;
  --cat-rgb: 97,236,255;
  min-height: 430px;
  height: 100%;
  padding: 24px 22px 20px !important;
  border-radius: 22px !important;
  display: flex !important;
  flex-direction: column;
  gap: 0;
  background:
    radial-gradient(circle at 18% 10%, rgba(var(--cat-rgb), 0.16), transparent 34%),
    linear-gradient(180deg, rgba(3, 7, 13, 0.96), rgba(5, 11, 20, 0.99)) !important;
  border: 1.5px solid color-mix(in srgb, var(--cat) 78%, transparent) !important;
  box-shadow:
    0 18px 42px rgba(0, 0, 0, 0.42),
    0 0 18px rgba(var(--cat-rgb), 0.26),
    inset 0 1px 0 rgba(255, 255, 255, 0.07) !important;
  color: #ffffff !important;
  overflow: hidden;
}
.listing-card-pro:hover,
.listing-card-pro:focus-within {
  transform: translateY(-2px);
  box-shadow:
    0 24px 54px rgba(0, 0, 0, 0.48),
    0 0 26px rgba(var(--cat-rgb), 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}
.cat-empleo { --cat:#0ea5ff; --cat-2:#075cff; --cat-rgb:14,165,255; }
.cat-rapido { --cat:#00f0ff; --cat-2:#009ea9; --cat-rgb:0,240,255; }
.cat-personal { --cat:#cc4dff; --cat-2:#7c10d8; --cat-rgb:204,77,255; }
.cat-profesional { --cat:#6cff1c; --cat-2:#238800; --cat-rgb:108,255,28; }
.cat-evento { --cat:#ff3131; --cat-2:#b90000; --cat-rgb:255,49,49; }
.cat-oferta { --cat:#ff3aa4; --cat-2:#b60067; --cat-rgb:255,58,164; }
.cat-comida { --cat:#d8aa3a; --cat-2:#7f5d15; --cat-rgb:216,170,58; }

.listing-card-head {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  min-width: 0;
}
.listing-icon-box,
.listing-date-box {
  width: 78px !important;
  height: 78px !important;
  min-height: 78px !important;
  flex: 0 0 78px;
  border-radius: 22px !important;
  background:
    radial-gradient(circle at 35% 18%, rgba(255,255,255,0.36), transparent 24%),
    linear-gradient(145deg, var(--cat), var(--cat-2)) !important;
  border: 1px solid rgba(255,255,255,0.24) !important;
  box-shadow:
    0 14px 26px rgba(0,0,0,0.35),
    0 0 22px rgba(var(--cat-rgb),0.36),
    inset 0 1px 0 rgba(255,255,255,0.28) !important;
  color: #ffffff !important;
}
.cat-comida .listing-icon-box {
  background:
    linear-gradient(135deg, rgba(255,255,255,0.22), transparent 24%),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.08) 0 2px, transparent 2px 7px),
    linear-gradient(145deg, #d8aa3a, #7f5d15) !important;
}
.listing-icon-box svg {
  width: 46px;
  height: 46px;
  fill: none;
  stroke: currentColor;
  stroke-width: 4.2;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: drop-shadow(0 6px 10px rgba(0,0,0,0.35));
}
.listing-date-box {
  background:
    linear-gradient(135deg, rgba(255,255,255,0.26), transparent 24%),
    linear-gradient(145deg, #ff3838, #8c0000) !important;
  color: #ffffff !important;
}
.listing-date-day,
.listing-date-month { color: #ffffff !important; }

.listing-head-text { min-width: 0; }
.listing-category-title {
  margin: 2px 0 14px;
  color: #fffdf8;
  font-size: clamp(1.5rem, 2.2vw, 2.1rem);
  font-weight: 900;
  line-height: 0.98;
  letter-spacing: -0.045em;
  text-transform: none;
  text-shadow: 0 2px 12px rgba(255,255,255,0.08), 0 12px 26px rgba(0,0,0,0.42);
}
.listing-title {
  margin: 0 0 6px !important;
  color: #ffffff !important;
  font-size: clamp(1.2rem, 1.45vw, 1.42rem) !important;
  font-weight: 850 !important;
  line-height: 1.14 !important;
  letter-spacing: -0.025em !important;
}
.listing-subline,
.listing-description,
.fact-line,
.fact-line span,
.listing-card-pro p {
  color: rgba(255,255,255,0.92) !important;
}
.listing-subline {
  margin: 0 !important;
  font-size: 1rem !important;
  line-height: 1.34 !important;
}
.listing-divider {
  height: 1px;
  margin: 18px 0 16px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.16), transparent);
}
.listing-facts {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
}
.fact-line {
  display: grid;
  grid-template-columns: 26px 1fr;
  align-items: center;
  gap: 10px;
  font-size: 1rem;
  line-height: 1.35;
  font-weight: 650;
}
.fact-icon {
  color: var(--cat) !important;
  font-weight: 900;
  text-align: center;
  text-shadow: 0 0 14px rgba(var(--cat-rgb),0.7);
}
.listing-description {
  margin: 0 0 18px !important;
  font-size: 0.98rem !important;
  line-height: 1.52 !important;
  min-height: 3rem;
}
.list-actions {
  margin-top: auto !important;
  display: flex !important;
}
.primary-contact-btn {
  width: 100%;
  min-height: 52px !important;
  border-radius: 12px !important;
  color: #ffffff !important;
  font-size: 1.02rem !important;
  font-weight: 900 !important;
  letter-spacing: -0.015em;
  background: linear-gradient(180deg, color-mix(in srgb, var(--cat) 84%, #ffffff 10%), color-mix(in srgb, var(--cat-2) 88%, #000000 12%)) !important;
  border: 1px solid rgba(255,255,255,0.22) !important;
  box-shadow: 0 10px 22px rgba(0,0,0,0.35), 0 0 18px rgba(var(--cat-rgb),0.28) !important;
}
.primary-contact-btn::after {
  content: ' →';
  margin-left: 8px;
}
.primary-contact-btn.is-disabled { opacity: 0.55; }

/* Ocultar etiquetas antiguas dentro de las cards premium */
.listing-card-pro .pill,
.listing-card-pro .listing-top,
.listing-card-pro .info-stack,
.listing-card-pro .info-row { display: none !important; }

/* Mobile: una card por fila, clara y rápida */
@media (max-width: 700px) {
  .services-grid,
  .grid-3 { grid-template-columns: 1fr !important; gap: 16px; }
  .listing-card-pro {
    min-height: 360px;
    padding: 22px 18px 18px !important;
  }
  .listing-card-head { gap: 14px; }
  .listing-icon-box,
  .listing-date-box {
    width: 64px !important;
    height: 64px !important;
    min-height: 64px !important;
    flex-basis: 64px;
    border-radius: 18px !important;
  }
  .listing-icon-box svg { width: 38px; height: 38px; }
  .listing-category-title { font-size: 1.5rem; margin-bottom: 12px; }
  .listing-title { font-size: 1.04rem !important; }
  .fact-line { font-size: 0.96rem; }
  .listing-description { min-height: auto; }
}


/* v17.1 desktop nav + search filters + benefits */
.desktop-nav {
  display: none;
  align-items: center;
  gap: 12px;
  margin-left: auto;
  margin-right: 18px;
}
.desktop-nav a {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0 10px;
  color: rgba(247,251,255,0.92);
  font-size: 1rem;
  font-weight: 600;
  border-radius: 12px;
  transition: color .18s ease, background .18s ease;
}
.desktop-nav a:hover,
.desktop-nav a:focus-visible,
.desktop-nav a.is-active {
  color: #ffffff;
  background: rgba(255,255,255,0.04);
  outline: none;
}
@media (min-width: 960px) {
  .desktop-nav { display: inline-flex; }
}
.search-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 18px;
}
.filter-chip {
  appearance: none;
  border: 1px solid rgba(151,211,255,0.14);
  background: linear-gradient(180deg, rgba(8,18,31,0.88), rgba(6,13,24,0.94));
  color: #ffffff;
  min-height: 48px;
  border-radius: 16px;
  padding: 10px 14px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 10px 20px rgba(0,0,0,0.18);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.filter-chip strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  height: 26px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
  color: #ffffff;
  font-size: .84rem;
}
.filter-chip:hover,
.filter-chip:focus-visible,
.filter-chip.is-active {
  transform: translateY(-1px);
  box-shadow: 0 14px 24px rgba(0,0,0,0.22), 0 0 16px rgba(97,236,255,0.18);
  outline: none;
}
.filter-chip-all.is-active { border-color: rgba(97,236,255,0.44); }
.filter-chip-trabajo.is-active { border-color: rgba(14,165,255,0.5); }
.filter-chip-trabajo_rapido.is-active { border-color: rgba(0,240,255,0.5); }
.filter-chip-servicio_personal.is-active { border-color: rgba(204,77,255,0.5); }
.filter-chip-servicio_profesional.is-active { border-color: rgba(108,255,28,0.5); }
.filter-chip-evento.is-active { border-color: rgba(255,49,49,0.5); }
.filter-chip-oferta.is-active { border-color: rgba(255,58,164,0.5); }
.filter-chip-comida.is-active { border-color: rgba(216,170,58,0.5); }
.benefit-section { padding-top: 0; }
.benefit-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 0;
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid rgba(151,211,255,0.14);
  background: linear-gradient(180deg, rgba(8,18,31,0.88), rgba(5,11,20,0.98));
  box-shadow: 0 16px 36px rgba(0,0,0,0.24);
}
.benefit-item {
  display: flex;
  gap: 14px;
  padding: 22px 20px;
  border-right: 1px solid rgba(151,211,255,0.10);
}
.benefit-item:last-child { border-right: 0; }
.benefit-icon {
  flex: 0 0 auto;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: var(--aqua);
}
.benefit-item strong {
  display: block;
  margin-bottom: 6px;
  font-size: 1rem;
  color: #ffffff;
}
.benefit-item span:last-child, .benefit-item div span {
  display: block;
  color: rgba(238,247,255,0.76);
  line-height: 1.55;
  font-size: 0.94rem;
}
@media (max-width: 900px) {
  .benefit-strip { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .benefit-item:nth-child(2) { border-right: 0; }
}
@media (max-width: 640px) {
  .desktop-nav { display: none !important; }
  .search-filter-row {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 4px;
    margin-right: -8px;
  }
  .search-filter-row::-webkit-scrollbar { display: none; }
  .filter-chip { white-space: nowrap; flex: 0 0 auto; }
  .benefit-strip { grid-template-columns: 1fr; }
  .benefit-item { border-right: 0; border-bottom: 1px solid rgba(151,211,255,0.10); }
  .benefit-item:last-child { border-bottom: 0; }
}


/* v20 — Publicar premium real: mismo lenguaje visual que Buscar */
.publish-premium-section {
  padding-top: 18px;
}

.publish-heading {
  margin-bottom: 16px;
}

.publish-premium-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: stretch;
}

@media (min-width: 760px) {
  .publish-premium-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.publish-premium-card {
  --cat: #61ecff;
  --cat-2: #1e86ff;
  --cat-rgb: 97,236,255;
  min-height: 315px;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 24px 22px 20px;
  border-radius: 24px;
  color: #ffffff;
  background:
    radial-gradient(circle at 18% 10%, rgba(var(--cat-rgb), 0.16), transparent 35%),
    linear-gradient(180deg, rgba(3, 7, 13, 0.96), rgba(5, 11, 20, 0.99));
  border: 1.5px solid color-mix(in srgb, var(--cat) 78%, transparent);
  box-shadow:
    0 18px 42px rgba(0,0,0,0.42),
    0 0 18px rgba(var(--cat-rgb),0.26),
    inset 0 1px 0 rgba(255,255,255,0.07);
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease;
}

.publish-premium-card:hover,
.publish-premium-card:focus-within {
  transform: translateY(-2px);
  box-shadow:
    0 24px 54px rgba(0,0,0,0.48),
    0 0 26px rgba(var(--cat-rgb),0.34),
    inset 0 1px 0 rgba(255,255,255,0.08);
}

.publish-premium-icon {
  width: 78px;
  height: 78px;
  min-height: 78px;
  border-radius: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  background:
    radial-gradient(circle at 35% 18%, rgba(255,255,255,0.36), transparent 24%),
    linear-gradient(145deg, var(--cat), var(--cat-2));
  border: 1px solid rgba(255,255,255,0.24);
  box-shadow:
    0 14px 26px rgba(0,0,0,0.35),
    0 0 22px rgba(var(--cat-rgb),0.36),
    inset 0 1px 0 rgba(255,255,255,0.28);
}

.publish-premium-icon svg {
  width: 46px;
  height: 46px;
  fill: none;
  stroke: currentColor;
  stroke-width: 4.2;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: drop-shadow(0 6px 10px rgba(0,0,0,0.35));
}

.publish-premium-card h3 {
  margin: 22px 0 14px;
  color: #fffdf8;
  font-size: clamp(1.45rem, 2.05vw, 2rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.045em;
  text-shadow: 0 2px 12px rgba(255,255,255,0.08), 0 12px 26px rgba(0,0,0,0.42);
}

.publish-premium-card p {
  margin: 0 0 20px;
  color: rgba(255,255,255,0.9);
  font-size: 1rem;
  line-height: 1.55;
}

.publish-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-top: auto;
  margin-bottom: 14px;
  min-height: 30px;
  padding: 7px 12px;
  border-radius: 999px;
  color: #ffffff;
  background: rgba(var(--cat-rgb),0.18);
  border: 1px solid rgba(var(--cat-rgb),0.36);
  font-size: .82rem;
  font-weight: 800;
}

.publish-badge.badge-blue {
  background: rgba(0, 240, 255, 0.16);
  border-color: rgba(0, 240, 255, 0.34);
}

.publish-badge.badge-gold {
  background: rgba(216,170,58,0.18);
  border-color: rgba(216,170,58,0.40);
}

.publish-keep-btn {
  width: 100%;
  min-height: 54px;
  justify-content: center;
  border-radius: 14px;
  color: #05101a !important;
  font-weight: 900;
  letter-spacing: -0.01em;
  background: linear-gradient(135deg, #72efff, #8dff74) !important;
  border: 0 !important;
  box-shadow: 0 12px 26px rgba(97,236,255,0.16), 0 0 20px rgba(141,255,116,0.10);
}

.publish-calendar-icon {
  background:
    linear-gradient(135deg, rgba(255,255,255,0.26), transparent 24%),
    linear-gradient(145deg, #ff3838, #8c0000) !important;
  flex-direction: column;
}

.calendar-day {
  font-size: 1.8rem;
  line-height: 1;
  font-weight: 950;
  color: #ffffff;
}

.calendar-month {
  margin-top: 4px;
  font-size: .78rem;
  font-weight: 900;
  color: #ffffff;
  letter-spacing: .04em;
}

.cat-empleo { --cat:#0ea5ff; --cat-2:#075cff; --cat-rgb:14,165,255; }
.cat-rapido { --cat:#00f0ff; --cat-2:#009ea9; --cat-rgb:0,240,255; }
.cat-personal { --cat:#cc4dff; --cat-2:#7c10d8; --cat-rgb:204,77,255; }
.cat-profesional { --cat:#6cff1c; --cat-2:#238800; --cat-rgb:108,255,28; }
.cat-evento { --cat:#ff3131; --cat-2:#b90000; --cat-rgb:255,49,49; }
.cat-oferta { --cat:#ff3aa4; --cat-2:#b60067; --cat-rgb:255,58,164; }
.cat-comida { --cat:#d8aa3a; --cat-2:#7f5d15; --cat-rgb:216,170,58; }

.cat-comida .publish-premium-icon {
  background:
    linear-gradient(135deg, rgba(255,255,255,0.22), transparent 24%),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.08) 0 2px, transparent 2px 7px),
    linear-gradient(145deg, #d8aa3a, #7f5d15) !important;
}

@media (max-width: 640px) {
  .publish-premium-card {
    min-height: 292px;
    padding: 22px 18px 18px;
  }
  .publish-premium-icon {
    width: 66px;
    height: 66px;
    min-height: 66px;
    border-radius: 19px;
  }
  .publish-premium-icon svg {
    width: 38px;
    height: 38px;
  }
  .publish-premium-card h3 {
    font-size: 1.48rem;
    margin-top: 18px;
    margin-bottom: 12px;
  }
}


/* v21 publish premium safe CSS */
/* Critical CSS v21: prevents broken Publish cards if old styles.css is cached */
.publish-premium-section{padding-top:18px}
.publish-heading{margin-bottom:16px}
.publish-premium-grid{display:grid;grid-template-columns:1fr;gap:18px;align-items:stretch}
@media (min-width:760px){.publish-premium-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
.publish-premium-card{
  --cat:#61ecff;--cat-2:#1e86ff;--cat-rgb:97,236,255;
  min-height:315px;height:100%;display:flex;flex-direction:column;gap:0;
  padding:24px 22px 20px;border-radius:24px;color:#fff;
  background:radial-gradient(circle at 18% 10%,rgba(var(--cat-rgb),.16),transparent 35%),linear-gradient(180deg,rgba(3,7,13,.96),rgba(5,11,20,.99));
  border:1.5px solid var(--cat);
  box-shadow:0 18px 42px rgba(0,0,0,.42),0 0 18px rgba(var(--cat-rgb),.26),inset 0 1px 0 rgba(255,255,255,.07);
  overflow:hidden;transition:transform .2s ease,box-shadow .2s ease
}
.publish-premium-card:hover,.publish-premium-card:focus-within{transform:translateY(-2px);box-shadow:0 24px 54px rgba(0,0,0,.48),0 0 26px rgba(var(--cat-rgb),.34),inset 0 1px 0 rgba(255,255,255,.08)}
.publish-premium-icon{
  width:78px;height:78px;min-height:78px;border-radius:22px;display:inline-flex;align-items:center;justify-content:center;color:#fff;
  background:radial-gradient(circle at 35% 18%,rgba(255,255,255,.36),transparent 24%),linear-gradient(145deg,var(--cat),var(--cat-2));
  border:1px solid rgba(255,255,255,.24);box-shadow:0 14px 26px rgba(0,0,0,.35),0 0 22px rgba(var(--cat-rgb),.36),inset 0 1px 0 rgba(255,255,255,.28)
}
.publish-premium-icon svg{width:46px!important;height:46px!important;fill:none!important;stroke:currentColor!important;stroke-width:4.2!important;stroke-linecap:round!important;stroke-linejoin:round!important;filter:drop-shadow(0 6px 10px rgba(0,0,0,.35))}
.publish-premium-card h3{margin:22px 0 14px;color:#fffdf8;font-size:clamp(1.45rem,2.05vw,2rem);font-weight:900;line-height:1;letter-spacing:-.045em;text-shadow:0 2px 12px rgba(255,255,255,.08),0 12px 26px rgba(0,0,0,.42)}
.publish-premium-card p{margin:0 0 20px;color:rgba(255,255,255,.9);font-size:1rem;line-height:1.55}
.publish-badge{display:inline-flex;align-items:center;width:fit-content;margin-top:auto;margin-bottom:14px;min-height:30px;padding:7px 12px;border-radius:999px;color:#fff;background:rgba(var(--cat-rgb),.18);border:1px solid rgba(var(--cat-rgb),.36);font-size:.82rem;font-weight:800}
.publish-badge.badge-blue{background:rgba(0,240,255,.16);border-color:rgba(0,240,255,.34)}
.publish-badge.badge-gold{background:rgba(216,170,58,.18);border-color:rgba(216,170,58,.40)}
.publish-keep-btn{width:100%;min-height:54px;justify-content:center;border-radius:14px;color:#05101a!important;font-weight:900;letter-spacing:-.01em;background:linear-gradient(135deg,#72efff,#8dff74)!important;border:0!important;box-shadow:0 12px 26px rgba(97,236,255,.16),0 0 20px rgba(141,255,116,.10)}
.publish-calendar-icon{background:linear-gradient(135deg,rgba(255,255,255,.26),transparent 24%),linear-gradient(145deg,#ff3838,#8c0000)!important;flex-direction:column}
.calendar-day{font-size:1.8rem;line-height:1;font-weight:950;color:#fff}.calendar-month{margin-top:4px;font-size:.78rem;font-weight:900;color:#fff;letter-spacing:.04em}
.cat-empleo{--cat:#0ea5ff;--cat-2:#075cff;--cat-rgb:14,165,255}.cat-rapido{--cat:#00f0ff;--cat-2:#009ea9;--cat-rgb:0,240,255}.cat-personal{--cat:#cc4dff;--cat-2:#7c10d8;--cat-rgb:204,77,255}.cat-profesional{--cat:#6cff1c;--cat-2:#238800;--cat-rgb:108,255,28}.cat-evento{--cat:#ff3131;--cat-2:#b90000;--cat-rgb:255,49,49}.cat-oferta{--cat:#ff3aa4;--cat-2:#b60067;--cat-rgb:255,58,164}.cat-comida{--cat:#d8aa3a;--cat-2:#7f5d15;--cat-rgb:216,170,58}
.cat-comida .publish-premium-icon{background:linear-gradient(135deg,rgba(255,255,255,.22),transparent 24%),repeating-linear-gradient(90deg,rgba(255,255,255,.08) 0 2px,transparent 2px 7px),linear-gradient(145deg,#d8aa3a,#7f5d15)!important}
@media (max-width:640px){.publish-premium-card{min-height:292px;padding:22px 18px 18px}.publish-premium-icon{width:66px;height:66px;min-height:66px;border-radius:19px}.publish-premium-icon svg{width:38px!important;height:38px!important}.publish-premium-card h3{font-size:1.48rem;margin-top:18px;margin-bottom:12px}}



/* v23 — Fast loading state + cached API rendering */
.loading-card {
  min-height: 300px;
  border-radius: 24px;
  padding: 24px 22px 20px;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.025), rgba(255,255,255,0.055), rgba(255,255,255,0.025)),
    linear-gradient(180deg, rgba(3,7,13,0.96), rgba(5,11,20,0.99));
  background-size: 220% 100%, auto;
  border: 1px solid rgba(151,211,255,0.18);
  animation: hlSkeleton 1.25s ease-in-out infinite;
}

.loading-icon {
  width: 78px;
  height: 78px;
  border-radius: 22px;
  background: rgba(255,255,255,0.10);
  margin-bottom: 26px;
}

.loading-line,
.loading-button {
  height: 16px;
  border-radius: 999px;
  background: rgba(255,255,255,0.11);
  margin-bottom: 14px;
}

.loading-title-line {
  width: 64%;
  height: 24px;
}

.loading-line.short {
  width: 48%;
}

.loading-button {
  margin-top: auto;
  height: 52px;
  width: 100%;
  background: linear-gradient(135deg, rgba(114,239,255,0.34), rgba(141,255,116,0.28));
}

@keyframes hlSkeleton {
  0% { background-position: 180% 0, 0 0; }
  100% { background-position: -80% 0, 0 0; }
}

.result-count {
  min-height: 1.4em;
}
