/* Base existente */
body { padding: 16px; }
.card-prop { min-height: 100%; }
.img-cover { width: 100%; height: 180px; object-fit: cover; background: #eee; }
.badge-thin { font-weight: 500; }
.ellipsis { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Header / icon buttons */
.icon-btn { display: inline-flex; align-items: center; gap: .4rem; }

/* Offcanvas slim (ancho amigable) */
.offcanvas-slim { width: min(420px, 100vw); }

/* ================================
   Brand
   ================================ */
.brand-logo { display:block; height:32px; width:auto; }
.navbar-brand .brand-text { letter-spacing:.2px; }


/* ================================
   Tokens & tema PASIÓN
   ================================ */
:root{
  --fp-pasion-blue:   #004c99;   /* azul pasion */
  --fp-pasion-blue-2: #173E69;   /* azul profundo */
  --fp-black:         #000000;
  --fp-white:         #ffffff;
  --fp-gold:          #D5B048;   /* dorado */
  --fp-cyan-accent:   #35b3ef;   /* cian de la demo */
  --fp-bg-cyan:       #f2f9ff;   /* fondo suave cian */
  --fp-text-main:     #101828;
  --fp-muted:         #6b7280;
}

/* Fondo general tipo demo (cian claro) */
body { background: var(--fp-bg-cyan); color: var(--fp-text-main); }

/* ================================
   HEADER full-bleed + Pasión
   ================================ */
/* Pinta el navbar y lo hace full-width aunque body tenga padding */
header.navbar{
  background: linear-gradient(120deg, var(--fp-black), var(--fp-pasion-blue)) !important;
  color: var(--fp-white);
  border-bottom: 1px solid rgba(255,255,255,.14) !important;

  /* full-bleed compensando el padding del body (16px) */
  margin-left: -16px; margin-right: -16px;
  padding-left: 16px; padding-right: 16px;
}

/* Marca + enlaces + iconos */
header.navbar .navbar-brand,
header.navbar .nav-link,
header.navbar .icon-btn,
header.navbar .icon-btn i { color: #fff !important; }
header.navbar .nav-link { opacity:.92; }
header.navbar .nav-link:hover, header.navbar .nav-link:focus { opacity:1; text-decoration:none; }

/* Botones dentro del header (outline → legibles en oscuro) */
header.navbar .btn-outline-secondary{
  color:#fff !important; border-color: rgba(255,255,255,.65) !important; background: transparent !important;
}
header.navbar .btn-outline-secondary:hover{ background: rgba(255,255,255,.12) !important; }
header.navbar .btn-outline-primary{
  color:#fff !important; border-color: var(--fp-cyan-accent) !important; background: transparent !important;
}
header.navbar .btn-outline-primary:hover{
  background: var(--fp-pasion-blue) !important; border-color: var(--fp-cyan-accent) !important;
}

/* ================================
   FOOTER full-bleed + Pasión
   ================================ */
/* Variante recomendada: usar <footer class="fp-footer-pasion"><div class="container fp-footer-inner">… */
.fp-footer-pasion{
  background: linear-gradient(120deg, var(--fp-black), var(--fp-pasion-blue));
  color:#fff; margin-top: 2rem;

  /* full-bleed compensando padding del body */
  margin-left: -16px; margin-right: -16px;
  padding-left: 16px; padding-right: 16px;
}
.fp-footer-pasion a{ color:#fff; opacity:.9; } .fp-footer-pasion a:hover{ opacity:1; }
.fp-footer-pasion .fp-footer-inner{ padding: 28px 0; }
@media (min-width:768px){ .fp-footer-pasion .fp-footer-inner{ padding: 44px 0; } }

/* Fallback (si aún no usás <footer>): aplica al bloque actual del footer.php */
body > .d-flex.flex-column.flex-md-row.justify-content-between.align-items-center.small.mt-3{
  background: linear-gradient(120deg, var(--fp-black), var(--fp-pasion-blue));
  color:#fff; margin-top: 2rem !important; border-top: 1px solid rgba(255,255,255,.12);
  border-radius: 10px;

  /* full-bleed compensando padding del body */
  margin-left: -16px; margin-right: -16px;
  padding: 28px 16px;
}
@media (min-width:768px){
  body > .d-flex.flex-column.flex-md-row.justify-content-between.align-items-center.small.mt-3{
    padding: 44px 16px;
  }
}
.marca-arnumis-footer{ font-weight:700; letter-spacing:.2px; }

/* ================================
   BOTONES (global)
   ================================ */
/* Regla general: azul pasión por defecto, hover dorado */
.btn-primary{
  background: var(--fp-pasion-blue) !important;
  border-color: var(--fp-pasion-blue) !important;
  color:#fff !important;
}
.btn-primary:hover, .btn-primary:focus{
  background: var(--fp-gold) !important;
  border-color: var(--fp-gold) !important;
  color:#111 !important;
}

/* Outline con mismo criterio */
.btn-outline-primary{
  color: var(--fp-pasion-blue) !important;
  border-color: var(--fp-pasion-blue) !important;
  background: transparent !important;
}
.btn-outline-primary:hover, .btn-outline-primary:focus{
  background: var(--fp-gold) !important;
  border-color: var(--fp-gold) !important;
  color: #111 !important;
}
.btn-outline-secondary{
  color: var(--fp-pasion-blue-2) !important;
  border-color: var(--fp-pasion-blue-2) !important;
  background: transparent !important;
}
.btn-outline-secondary:hover, .btn-outline-secondary:focus{
  background: var(--fp-gold) !important;
  border-color: var(--fp-gold) !important;
  color:#111 !important;
}

/* CTA "Ver publicación": default dorado sólido; hover azul Pasión */
.btn-publicacion{
  background: var(--fp-gold) !important;
  border-color: var(--fp-gold) !important;
  color: #111 !important;
  transition: background-color .15s ease, border-color .15s ease, color .15s ease, box-shadow .15s ease;
}
.btn-publicacion:hover,
.btn-publicacion:focus{
  background: var(--fp-pasion-blue) !important;
  border-color: var(--fp-pasion-blue) !important;
  color: #fff !important;
  box-shadow: 0 0 0 .2rem rgba(0,76,153,.18);
}


/* ================================
   PAGINADOR (azul → hover dorado)
   ================================ */
.pagination .page-link{
  color: var(--fp-pasion-blue-2);
  border: 1px solid #d8dfea;
  background: #fff;
  border-radius: 10px;
}
.pagination .page-link:hover{
  background: var(--fp-gold);
  border-color: var(--fp-gold);
  color: #111;
}
.pagination .page-item.active .page-link{
  background: var(--fp-gold);
  border-color: var(--fp-gold);
  color: #111;
}
.pagination .page-link:focus{
  box-shadow: 0 0 0 .2rem rgba(213,176,72,.35) !important;
}

/* ================================
   SCROLL-TO-TOP (dorado → hover negro)
   ================================ */
.btn-scroll-top{
  position: fixed;
  right: 16px; bottom: 16px;
  width: 44px; height: 44px; padding: 0; border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;

  /* visibilidad */
  opacity: 0; pointer-events: none; transform: translateY(10px);
  transition: opacity .2s ease, transform .2s ease;

  /* por encima de backdrop/offcanvas/navbar */
  z-index: 2000;

  /* look Pasión */
  background: var(--fp-gold) !important; color: #111 !important;
  border: none !important; box-shadow: 0 10px 20px rgba(0,0,0,.25);
}
.btn-scroll-top.show{ opacity:1; pointer-events:auto; transform: translateY(0); }
.btn-scroll-top:hover, .btn-scroll-top:focus{
  background:#000 !important; color: var(--fp-gold) !important;
  box-shadow: 0 12px 22px rgba(0,0,0,.35);
}
.btn-scroll-top i{ font-size:1.1rem; }


/* ================================
   Inputs sobre fondo cian
   ================================ */
.form-control, .form-select{
  background: #fff; border-color: #d8dfea; color: var(--fp-text-main);
}
.form-control:focus, .form-select:focus{
  border-color: var(--fp-pasion-blue);
  box-shadow: 0 0 0 .2rem rgba(0,76,153,.18);
}

/* ====================
   Contenedor de card
   ==================== */
.fp-hl-ribbon{
  position:absolute; top:8px; left:-6px;
  padding:4px 10px; transform:rotate(-6deg);
  background: var(--hl, #FAD24A); color:#111;
  font-weight:700; font-size:.75rem; border-radius:4px;
  box-shadow:0 2px 6px rgba(0,0,0,.15); pointer-events:none; z-index:5;
}
.fp-hl-badge{
  position:absolute; top:8px; right:8px;
  background: var(--hl, #FAD24A); color:#111;
  padding:3px 8px; border-radius:999px; font-size:.75rem; font-weight:700;
  box-shadow:0 2px 6px rgba(0,0,0,.15); pointer-events:none; z-index:5;
}
.fp-hl-corner::after{
  content: attr(data-label);
  position:absolute; top:0; right:0; transform:translate(30%,-30%) rotate(45deg);
  background: var(--hl, #FAD24A); color:#111; font-size:.7rem; font-weight:700; padding:3px 24px;
  box-shadow:0 2px 6px rgba(0,0,0,.15); pointer-events:none; z-index:5;
}

