/* ================================================================
   TexasInmateSearch.com, Local Partner Spot Cards (lps-*)
   ================================================================ */

.lps-section { padding: 48px 0 56px; }

.lps-duo {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}

@media (max-width: 768px) { .lps-duo { grid-template-columns: 1fr; } }

.lps-col-label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(255,255,255,.35);
    margin: 0 0 10px 4px;
}

/* Base card */
.lps-card {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    background: #1C100A;
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 4px 24px rgba(0,0,0,.22), 0 1px 4px rgba(0,0,0,.12);
    display: flex;
    flex-direction: column;
    transition: transform .2s ease, box-shadow .2s ease;
}
.lps-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 36px rgba(0,0,0,.32), 0 2px 8px rgba(0,0,0,.15);
}

/* Badges */
.lps-badge {
    position: absolute;
    top: 14px; left: 14px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px 4px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .04em;
    z-index: 10;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.lps-badge svg { width: 12px; height: 12px; flex-shrink: 0; }
.lps-badge--verified {
    background: rgba(16,185,129,.18);
    border: 1px solid rgba(16,185,129,.5);
    color: #34d399;
}
.lps-badge--open {
    background: rgba(240,192,64,.15);
    border: 1px solid rgba(240,192,64,.4);
    color: #E09210;
    left: auto; right: 14px;
}

/* ── Banner mode ──────────────────────────────────────────── */
.lps-banner {
    width: 100%; height: 195px;
    overflow: hidden; position: relative; flex-shrink: 0;
}
.lps-banner img {
    width: 100%; height: 100%;
    object-fit: cover; object-position: center top; display: block;
}
.lps-brand-badge {
    position: absolute;
    bottom: -22px; left: 18px;
    width: 62px; height: 62px;
    border-radius: 14px;
    border: 2.5px solid rgba(255,255,255,.2);
    background: #1C100A;
    overflow: hidden;
    box-shadow: 0 4px 18px rgba(0,0,0,.5);
    z-index: 2; flex-shrink: 0;
}
.lps-brand-badge img {
    width: 100%; height: 100%;
    object-fit: contain; padding: 7px; display: block;
}
.lps-brand-badge span {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    font-size: 20px; font-weight: 800; color: #E01040; letter-spacing: -.02em;
}
.lps-card--banner .lps-body { padding-top: 34px; }

/* ── Logo-only mode ───────────────────────────────────────── */
.lps-logo-zone {
    width: 100%; background: #111e2e;
    border-bottom: 1px solid rgba(255,255,255,.06);
    display: flex; align-items: center; justify-content: center;
    padding: 28px 32px; min-height: 150px; flex-shrink: 0;
}
.lps-logo-zone img {
    max-width: 75%; max-height: 150px;
    width: auto; height: auto;
    object-fit: contain; display: block;
    filter: drop-shadow(0 2px 14px rgba(0,0,0,.45));
}

/* ── No-image avatar ──────────────────────────────────────── */
.lps-avatar {
    width: 72px; height: 72px; border-radius: 18px;
    background: rgba(191,10,48,.08);
    border: 1.5px solid rgba(191,10,48,.22);
    display: flex; align-items: center; justify-content: center;
    font-size: 26px; font-weight: 800; color: #E01040;
    letter-spacing: -.02em; flex-shrink: 0;
}

/* Card body */
.lps-body {
    flex: 1; padding: 20px 22px 16px;
    display: flex; flex-direction: column; gap: 14px;
}
.lps-name-block { flex: 1; }
.lps-name {
    font-size: 18px; font-weight: 700; color: #fff;
    margin: 0 0 4px; line-height: 1.3; letter-spacing: -.02em;
}
.lps-tagline { font-size: 13px; color: #64748b; margin: 0; line-height: 1.5; }

/* Phone */
.lps-phone {
    display: flex; align-items: center; gap: 10px;
    background: rgba(191,10,48,.1);
    border: 1px solid rgba(191,10,48,.28);
    border-radius: 10px; padding: 10px 16px;
    color: #FF6080; font-size: 20px; font-weight: 700;
    letter-spacing: .02em; text-decoration: none;
    transition: background .18s ease, color .18s ease;
}
.lps-phone:hover { background: rgba(191,10,48,.2); color: #FFA0B0; }
.lps-phone svg { width: 18px; height: 18px; flex-shrink: 0; color: #E01040; }

/* Chips */
.lps-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.lps-chip {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.10);
    border-radius: 999px; padding: 4px 11px;
    font-size: 12px; color: #94a3b8; white-space: nowrap;
}
.lps-chip-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: #4ade80; flex-shrink: 0;
    box-shadow: 0 0 6px #4ade80;
    animation: lps-dot-pulse 2s infinite;
}
@keyframes lps-dot-pulse { 0%,100%{opacity:1} 50%{opacity:.45} }

/* Website link */
.lps-link {
    display: inline-block; color: #E01040;
    font-size: 13px; font-weight: 600; text-decoration: none;
    transition: color .15s ease;
}
.lps-link:hover { color: #FF6080; text-decoration: underline; }

/* Footer */
.lps-footer {
    padding: 8px 22px; font-size: 10px; font-weight: 700;
    letter-spacing: .12em; text-transform: uppercase;
    color: rgba(255,255,255,.22);
    border-top: 1px solid rgba(255,255,255,.05);
    background: rgba(0,0,0,.12);
}

/* ── Available spot card ──────────────────────────────────── */
.lps-card--available {
    background: #1C100A;
    border: 1px dashed rgba(240,192,64,.35);
    min-height: 320px; justify-content: center; align-items: center;
}
.lps-avail-body {
    padding: 44px 28px 36px;
    display: flex; flex-direction: column;
    align-items: center; text-align: center; gap: 12px;
}
.lps-avail-icon {
    width: 52px; height: 52px;
    background: rgba(240,192,64,.1);
    border: 1px solid rgba(240,192,64,.25);
    border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 4px;
}
.lps-avail-icon svg { width: 26px; height: 26px; }
.lps-avail-headline {
    font-size: 20px; font-weight: 800; color: #fff;
    margin: 0; line-height: 1.3; letter-spacing: -.025em;
}
.lps-avail-sub { font-size: 14px; color: #64748b; margin: 0; line-height: 1.6; max-width: 280px; }
.lps-avail-note { font-size: 12px; color: rgba(255,255,255,.28); margin: 0; }
.lps-avail-btn {
    display: inline-block; margin-top: 8px; padding: 13px 28px;
    background: #C97D00; color: #111827;
    font-size: 14px; font-weight: 800; letter-spacing: .01em;
    border-radius: 10px; text-decoration: none;
    box-shadow: 0 4px 14px rgba(201,125,0,.35);
    transition: background .18s ease, transform .15s ease, box-shadow .18s ease;
}
.lps-avail-btn:hover {
    background: #E09210; color: #111827;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(201,125,0,.5);
}

/* Mobile */
@media (max-width: 480px) {
    .lps-phone { font-size: 17px; }
    .lps-banner { height: 160px; }
    .lps-logo-zone { min-height: 120px; padding: 20px 24px; }
    .lps-avail-body { padding: 32px 20px 28px; }
}
