/* =============================================================
   Request Space Card — global styles for display_request_space_box()
   Used on: landlord/requests, office-space/request/, new_search, tenant pages
   ============================================================= */

/* ── Card container ── */
.ot-req-card {
    background: #fff;
    border: 1px solid #e5eaf4;
    border-radius: 16px;
    box-shadow: 0 2px 16px rgba(13, 31, 60, 0.06);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform 0.22s ease, box-shadow 0.22s ease;
    height: 100%;
}
.ot-req-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 32px rgba(13, 31, 60, 0.12);
}

/* ── Image area ── */
.ot-req-card .main-building-image {
    position: relative;
    overflow: hidden;
    height: 170px;
    flex-shrink: 0;
}
.ot-req-card .main-building-image img {
    width: 100%;
    height: 170px;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}
.ot-req-card:hover .main-building-image img {
    transform: scale(1.05);
}

/* Company / email overlay on image */
.ot-req-card .request-overlay {
    position: absolute;
    bottom: 8px;
    left: 8px;
    right: 8px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    z-index: 3;
}
.ot-req-card .overlay-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 6px;
    font-size: 0.72rem;
    font-weight: 600;
    font-family: "Plus Jakarta Sans", sans-serif;
    backdrop-filter: blur(4px);
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.ot-req-card .overlay-company { background: rgba(13, 31, 60, 0.78); color: #fff; }
.ot-req-card .overlay-email   { background: rgba(13, 148, 136, 0.82); color: #fff; }

/* Unit badge */
.ot-req-card .text-block {
    position: absolute;
    top: 10px;
    right: 10px;
    background: rgba(13, 148, 136, 0.90);
    color: #fff;
    border-radius: 6px;
    padding: 2px 8px;
    font-size: 0.72rem;
    font-weight: 700;
    font-family: "Plus Jakarta Sans", sans-serif;
    z-index: 3;
}
.ot-req-card .text-block p { margin: 0; }

/* ── Caption / body ── */
.ot-req-card .portfolio-caption {
    background: #fff !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 12px 14px 6px !important;
    text-align: left !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
}
.ot-req-card .portfolio-caption h4 {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 0.92rem;
    font-weight: 700;
    color: #0d1f3c !important;
    margin: 0 0 5px !important;
    line-height: 1.35;
}
.ot-req-card .portfolio-caption .space_details {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 0.78rem;
    color: #6b7a99 !important;
    margin: 0 0 3px !important;
    line-height: 1.5;
    display: flex;
    align-items: center;
    gap: 6px;
}
.ot-req-card .portfolio-caption .space_details i {
    font-size: 0.75rem;
    flex-shrink: 0;
    color: #0d9488;
}
.ot-req-card .portfolio-caption .space_details .fa-map-marker { color: #e11d48; }

/* ── Lead type badges ── */
.ot-req-card .req-lead-badge {
    display: inline-block;
    align-self: flex-start;
    padding: 3px 10px;
    border-radius: 999px;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    margin-bottom: 5px;
}
.ot-req-card .req-lead-tenant { background: #e8f7ec; color: #1f7a3f; }
.ot-req-card .req-lead-my     { background: #fdecea; color: #b42318; }
.ot-req-card .req-lead-public { background: #eef4ff; color: #2457c5; }

/* ── Size pill ── */
.ot-req-card .req-size-pill {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    background: linear-gradient(135deg, #0d1f3c 0%, #1a4b8a 52%, #0d9488 100%);
    color: #fff;
    border-radius: 8px;
    padding: 8px 14px;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 0.78rem;
    font-weight: 700;
    margin-top: 6px;
    margin-bottom: 6px;
    letter-spacing: 0.01em;
}
.ot-req-card .req-size-pill i { font-size: 0.8rem; opacity: 0.9; }

/* ── Action buttons ── */
.ot-req-card .portfolio-footer {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 8px 14px 14px !important;
    border-top: none !important;
    background: #fff !important;
    margin: 0 !important;
}
.ot-req-card .portfolio-footer .btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    padding: 6px 14px !important;
    border-radius: 8px !important;
    font-size: 0.74rem !important;
    font-weight: 600 !important;
    font-family: "Plus Jakarta Sans", sans-serif !important;
    text-decoration: none !important;
    transition: opacity 0.18s, transform 0.18s !important;
    cursor: pointer !important;
    line-height: 1.2 !important;
    border: none !important;
}
.ot-req-card .portfolio-footer .btn:hover {
    opacity: 0.85 !important;
    transform: translateY(-1px) !important;
    text-decoration: none !important;
}
.ot-req-card .portfolio-footer .btn-info {
    background: linear-gradient(135deg, #0d9488, #0a766d) !important;
    color: #fff !important;
}
.ot-req-card .portfolio-footer .btn-success {
    background: linear-gradient(135deg, #16a34a, #15803d) !important;
    color: #fff !important;
    box-shadow: none !important;
    animation: none !important;
}

/* ── Matched Spaces strip ── */
.ot-req-card .office-box {
    background: #fff !important;
    border-top: 1px solid #eef1f6 !important;
    padding: 8px 14px 12px !important;
    position: relative;
}
.ot-req-card .office-box:not(:empty)::before {
    content: "Matched Spaces";
    display: block;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    color: #b0bdd0;
    margin-bottom: 7px;
}
.ot-req-card .office-box .load-more-btn {
    font-size: 0.71rem;
    font-family: "Plus Jakarta Sans", sans-serif;
    color: #0d9488;
    font-weight: 600;
    text-decoration: none;
    display: inline-block;
    margin-top: 6px;
}
.ot-req-card .office-grid {
    display: grid !important;
    grid-template-columns: repeat(5, 1fr) !important;
    gap: 5px !important;
    padding: 0 !important;
}
.ot-req-card .office-item .building-image-container {
    border-radius: 7px;
    overflow: hidden;
    height: 40px !important;
    width: 100% !important;
    position: relative;
    box-shadow: 0 1px 4px rgba(13, 31, 60, 0.08);
}
.ot-req-card .office-item .building-image-container img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    transition: transform 0.2s ease !important;
}
.ot-req-card .office-item:hover .building-image-container img {
    transform: scale(1.08) !important;
}
.ot-req-card .unit-label {
    position: absolute !important;
    bottom: 0 !important;
    right: 0 !important;
    background: rgba(13, 31, 60, 0.65) !important;
    color: #fff !important;
    font-size: 9px !important;
    font-weight: 700 !important;
    padding: 1px 4px !important;
    border-radius: 4px 0 0 0 !important;
    line-height: 1.5 !important;
}

/* =============================================================
   Mobile / responsive overrides
   ============================================================= */
@media (max-width: 767px) {
    .ot-req-card .main-building-image,
    .ot-req-card .main-building-image img {
        height: 150px !important;
    }
    .ot-req-card .portfolio-caption {
        padding: 10px 12px 4px !important;
    }
    .ot-req-card .portfolio-caption h4 {
        font-size: 0.85rem !important;
    }
    .ot-req-card .portfolio-caption .space_details {
        font-size: 0.74rem !important;
    }
    .ot-req-card .req-size-pill {
        font-size: 0.74rem;
        padding: 7px 12px;
    }
    .ot-req-card .portfolio-footer .btn {
        font-size: 0.7rem !important;
        padding: 5px 10px !important;
    }
    .ot-req-card .office-grid {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

@media (max-width: 480px) {
    .ot-req-card .office-grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }
    .ot-req-card .portfolio-footer {
        padding: 6px 12px 10px !important;
    }
}
