/* ════════════════════════════════════════════════════
   BABADITOS COLOMBIA — Responsive v3 "Nebula"
════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════════════════════
   NAVEGACIÓN INFERIOR MÓVIL (estilo app / Facebook)
   Barra persistente Chat/Salas/Anuncios al pie. El header de cada sección queda
   mínimo (arriba solo: abrir chats izq., y conectados+campana+tema+admin+perfil
   der.). Las secciones (Salas/Anuncios/Feed) y el chat dejan espacio al pie.
   ════════════════════════════════════════════════════════════════════════ */
:root { --bottom-nav-h: 56px; }
.app-bottom-nav {
    display: none;
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 2500;
    background: var(--bg-raised); border-top: 1px solid var(--border);
    box-shadow: 0 -2px 16px rgba(0,0,0,.18);
    padding-bottom: env(safe-area-inset-bottom);
}
.abn-btn {
    flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 3px; height: var(--bottom-nav-h); background: none; border: none; cursor: pointer;
    color: var(--text-muted); font-size: .62rem; font-weight: 700;
    transition: color .15s; position: relative;
}
.abn-btn i { font-size: 1.2rem; }
.abn-btn.active { color: var(--primary); }
.abn-btn.active::before {
    content: ''; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
    width: 30px; height: 3px; border-radius: 0 0 3px 3px; background: var(--primary);
}

@media (max-width: 768px) {
    .app-bottom-nav { display: flex; }
    /* El chat se reduce para dejar ver la barra inferior (su input queda encima). */
    .chat-container {
        height: calc(100vh - var(--bottom-nav-h)); /* fallback */
        height: calc(100dvh - var(--bottom-nav-h) - env(safe-area-inset-bottom));
    }
    /* Las páginas de sección dejan aire al final para no quedar bajo la barra. */
    .classifieds-page, .pvrooms-page, .feed-page {
        padding-bottom: calc(var(--bottom-nav-h) + env(safe-area-inset-bottom));
    }
    /* Los cajones (chats/conectados) también dejan aire para su último elemento. */
    .sidebar { padding-bottom: calc(var(--bottom-nav-h) + env(safe-area-inset-bottom)); }
    /* En el PERFIL también queremos la barra inferior (Chat/Salas/Anuncios) a la
       vista; el perfil (z-9000) la tapaba. Al abrirlo (body.pfp-open) la subimos
       por encima y el cuerpo del perfil deja aire al final para su última tarjeta. */
    body.pfp-open .app-bottom-nav { z-index: 9500; }
    .pfp-root .pfp-body { padding-bottom: calc(var(--bottom-nav-h) + env(safe-area-inset-bottom) + 12px); }
    /* Quitar los botones flotantes (FAB): ahora todo va en header + barra inferior. */
    .mobile-fab { display: none !important; }
    /* Las pestañas Chat/Salas/Anuncios del top unificado pasan a la barra inferior. */
    .app-topbar .pfp-nav-center { display: none; }
    /* En las secciones, la marca se oculta y el buscador de personas ocupa el
       ancho (el usuario lo quiere visible en móvil). */
    .app-topbar .pfp-nav-brand { display: none; }
    .app-topbar .pfp-nav-left { flex: 1; min-width: 0; }
    .app-topbar .pfp-search { display: flex !important; flex: 1; min-width: 0; }
    /* Botón del header que abre el cajón de chats (solo móvil). */
    .mobile-only { display: inline-flex !important; }
}
.mobile-only { display: none; }

/* ════════════════════════════════════════════════════════════════════════
   PERFIL EN MÓVIL (estilo Facebook): topnav limpia (volver + búsqueda), info
   básica centrada y legible sobre la portada (antes apiñada a la derecha).
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    /* Topnav: botón "volver" + buscador a lo ancho; pestañas y marca fuera
       (la navegación entre secciones está en la barra inferior tras volver). */
    .pfp-topnav { padding: 0 10px !important; gap: 6px; }
    .pfp-topnav .pfp-nav-center { display: none; }
    .pfp-topnav .pfp-nav-brand { display: none; }
    .pfp-topnav .pfp-nav-left { flex: 1; min-width: 0; gap: 8px; }
    .pfp-topnav .pfp-search { display: flex !important; flex: 1; min-width: 0; max-width: none; }
    /* La derecha NO compite con la búsqueda: ancho fijo, iconos compactos. */
    .pfp-topnav .pfp-nav-right { flex: 0 0 auto; gap: 2px; }
    .pfp-topnav .pfp-nav-ico { width: 36px; height: 36px; font-size: .9rem; }
    .pfp-nav-back {
        display: inline-flex; align-items: center; justify-content: center;
        width: 36px; height: 36px; flex-shrink: 0; border: none; cursor: pointer;
        border-radius: 50%; background: var(--bg-hover); color: var(--text-primary);
    }
    /* ── Cabecera HERO móvil: TODO el contenido (avatar + nombre + botones) va
       SUPERPUESTO sobre la portada (sin tarjeta blanca debajo). La portada
       "abarca" todo y las pestañas quedan pegadas justo debajo. El header se
       sube con margin-top negativo: ese mismo margen tira de las pestañas hacia
       arriba, así NO queda espacio en blanco entre portada y contenido. */
    .pfp-cover-hero { border-radius: 0 !important; height: 260px !important; position: relative; }
    /* Degradado oscuro abajo para que el texto blanco sea legible sobre la foto. */
    .pfp-cover-hero .pfp-cover-gradient {
        background: linear-gradient(to top, rgba(0,0,0,.72) 0%, rgba(0,0,0,.35) 26%, transparent 58%) !important;
    }
    .pfp-profile-header {
        position: relative; z-index: 2;
        flex-direction: row; flex-wrap: nowrap; align-items: flex-end !important;
        justify-content: space-between;
        margin-top: -106px !important; padding: 0 16px 14px !important; gap: 10px;
        background: transparent !important;
    }
    .pfp-header-left { flex-direction: row; align-items: flex-end; gap: 12px; flex: 1 1 auto; min-width: 0; }
    .pfp-avatar-area { margin-top: 0; flex: 0 0 auto; }
    .pfp-avatar-lg { width: 92px !important; height: 92px !important; border-width: 4px !important; }
    .pfp-header-info { text-align: left; min-width: 0; padding-bottom: 2px; }
    /* Texto blanco legible sobre la portada. */
    .pfp-display-name { font-size: 1.35rem; color: #fff !important; text-shadow: 0 2px 10px rgba(0,0,0,.75); }
    .pfp-status-label { color: #f1f5f9 !important; text-shadow: 0 1px 6px rgba(0,0,0,.65); }
    .pfp-bio-text { color: #e8edf3 !important; text-shadow: 0 1px 6px rgba(0,0,0,.65); }
    .pfp-meta-chips { justify-content: flex-start; }
    .pfp-header-right { width: auto; padding-top: 0 !important; align-items: flex-end; }
    /* Botones a la DERECHA (no debajo de la foto), sobre la portada, al pie. */
    .pfp-action-btns { flex: 0 0 auto; justify-content: flex-end; flex-wrap: wrap; gap: 8px; width: auto; margin-top: 0; }
    .pfp-action-btns > * { flex: 0 0 auto; }
    .pfp-action-btns .pfp-btn-primary,
    .pfp-action-btns .pfp-btn-secondary,
    .pfp-action-btns .pfp-btn-outline { padding: 9px 15px; font-size: .82rem; }
    /* Pestañas (Publicaciones/Fotos/Información/Seguidores/Siguiendo) como PILLS
       con icono + etiqueta, que se deslizan; la activa resaltada. Antes salían
       como iconos sueltos (etiquetas ocultas) y se veían mal. */
    .pfp-tabs-bar { padding: 6px 8px !important; gap: 5px; }
    .pfp-tab-btn { padding: 8px 13px !important; margin: 0 !important; font-size: .76rem !important; border-radius: 999px; gap: 6px; flex: 0 0 auto; }
    .pfp-tab-btn span { display: inline !important; }
    .pfp-tab-btn i { font-size: .9rem; }
    .pfp-tab-btn.active { color: var(--primary); background: var(--primary-dim); font-weight: 700; }
    .pfp-tab-indicator { display: none !important; }
}
@media (max-width: 480px) {
    /* Portada hero más baja en teléfonos; el contenido sigue superpuesto. */
    .pfp-cover-hero { height: 220px !important; }
    .pfp-profile-header { margin-top: -98px !important; padding: 0 14px 12px !important; }
    .pfp-avatar-area { margin-top: 0; }
    .pfp-avatar-lg { width: 84px !important; height: 84px !important; }
    .pfp-header-info { padding-top: 0; }
    .pfp-display-name { font-size: 1.2rem; }
    /* En teléfonos muy angostos, los botones se apilan a la derecha para caber. */
    .pfp-action-btns .pfp-btn-primary { padding: 8px 13px; font-size: .8rem; }
}

/* ── Endurecimiento global móvil ─────────────────────
   Evita el problema #1 en móvil: desbordes horizontales que cortan secciones
   o crean scroll lateral, y texto largo (URLs, nombres) que rompe el layout. */
html, body { max-width: 100%; overflow-x: hidden; }
img, video, canvas, svg { max-width: 100%; height: auto; }
/* El texto largo se ajusta en vez de desbordar */
.message-content, .ad-description, .cls-card-desc, .cls-card-title,
.pfp-bio-text, .notification-item-text, .pvx-rh-meta, .anuncio-card-title,
.my-banner-title, .feed-post-text, .pfp-comment-text {
    overflow-wrap: anywhere; word-break: break-word;
}

@media (max-width: 768px) {
    /* iOS hace zoom automático al enfocar un input con font-size < 16px. Forzar
       16px en los campos de texto evita ese salto molesto (sobre todo el input
       del chat al escribir). */
    input[type="text"], input[type="search"], input[type="url"], input[type="tel"],
    input[type="email"], input[type="password"], input[type="number"], input[type="date"],
    input:not([type]), select, textarea,
    .ad-form-input, .ad-form-select, .ad-form-textarea, .cls-input, .pvx-input,
    .pvrooms-form-input, .input-wrapper input, #messageInput, .wa-composer input,
    #adChatInput, #waSearch {
        font-size: 16px;
    }
    /* Cualquier modal con overlay genérico cabe en la pantalla */
    .banner-edit-card { width: 94vw; max-width: 94vw; }
    /* Visor de imagen a pantalla completa (chat público y privado): el botón de
       cerrar colgaba fuera del contenedor (top/right:-12px) y se recortaba en
       móvil. Se ancla dentro, siempre tocable. */
    .close-fullscreen-img { top: 8px !important; right: 8px !important; }
    /* El pie del previsualizador de imagen (toggle "ver una vez" + botones) se
       reparte en varias líneas en vez de desbordar. */
    .image-preview-footer { flex-wrap: wrap; }
    .image-preview-modal { width: 94%; }
    /* Carruseles/tiras horizontales permiten desplazamiento táctil sin cortar */
    .rooms-navbar .navbar-content, .anuncios-categories, .users-subtabs,
    .modtabs, .pvx-set-nav { -webkit-overflow-scrolling: touch; }
}

/* ── Tablet landscape ───────────────────────────── */
@media (max-width: 1024px) {
    :root { --sidebar-w: 250px; }
    .icon-nav-strip { width: 50px; }
    .icon-nav-btn { width: 40px; }
    .icon-nav-btn i { font-size: .95rem; }
    .icon-nav-btn span { font-size: .52rem; }
    .message { max-width: 85%; }
    .rooms-grid { grid-template-columns: repeat(auto-fill, minmax(155px, 1fr)); }
    .admin-dashboard-grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
}

/* ── Tablet portrait ────────────────────────────── */
@media (max-width: 768px) {
    .icon-nav-strip { display: none; }
    .anuncios-header { padding: 0 .75rem; gap: .5rem; }
    .anuncios-brand span { display: none; }
    .anuncios-header-center { padding: 0 .3rem; }
    .anuncios-my-btn span { display: none; }
    .anuncios-publish-btn { padding: .45rem .65rem; font-size: .78rem; }
    .anuncios-categories { padding: .5rem .75rem; gap: .25rem; }
    .anuncios-cat-btn { padding: .35rem .6rem; font-size: .72rem; }
    .anuncios-body { padding: .75rem; }
    .anuncios-grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: .75rem; }
    .anuncio-detail-modal { max-width: 95vw; }
    .ad-form-row { flex-direction: column; gap: .5rem; }
    .mobile-menu-btn { display: flex !important; }
    .app-brand .brand-name { display: none; }
    .header-center { display: none; }
    .user-details { display: none; }
    .header-right { gap: 0.3rem; }

    .sidebar {
        position: fixed;
        top: 0; bottom: 0;
        z-index: 1500;
        width: 85%;
        max-width: 320px;
        transform: translateX(-105%);
        transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
        box-shadow: 6px 0 40px rgba(0, 0, 0, 0.5);
        background: var(--bg-raised);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
    }
    .sidebar.active { transform: translateX(0); }

    .right-sidebar {
        left: auto; right: 0;
        transform: translateX(105%);
        border-left: 1px solid var(--border);
        border-right: none;
    }
    .right-sidebar.active { transform: translateX(0); }

    .close-sidebar { display: flex !important; }
    .rooms-navbar { display: block; }

    .message { max-width: 90%; }
    .messages-container { padding: 0.85rem; }

    .navbar-content { padding: 0 0.75rem; gap: 0.3rem; }
    .main-room-tag span,
    .room-tag span,
    .private-chat-tag span { font-size: 0.75rem; }
    .add-rooms-btn span { display: none; }
    .add-rooms-btn { padding: 0.3rem 0.7rem; }

    .message-input-container { padding: 0.65rem 0.85rem; }

    .mobile-fab { display: flex; }

    .modal-container {
        border-radius: var(--r-lg);
        max-height: 93vh;
        max-width: 95vw;
    }
    .rooms-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }

    .admin-tabs {
        overflow-x: auto; scrollbar-width: none;
        padding: 0 0.75rem;
    }
    .admin-tabs::-webkit-scrollbar { display: none; }
    .admin-tab { white-space: nowrap; font-size: 0.75rem; padding: 0.62rem 0.85rem; }
    .admin-sections { padding: 1rem; }
    .stats-grid { grid-template-columns: repeat(auto-fit, minmax(155px, 1fr)); }

    .chat-header { padding: 0 0.75rem; }
    .header-left { min-width: auto; }
    .header-right { min-width: auto; }
}

/* ── Mobile ─────────────────────────────────────── */
@media (max-width: 480px) {
    .anuncios-grid { grid-template-columns: 1fr; }
    .anuncio-card-img { height: 150px; }
    .anuncios-publish-btn span { display: none; }
    .anuncios-header { height: 48px; }
    .upgrade-plan-card { padding: .5rem; }

    .login-container { padding: 1rem; }
    .login-card { max-width: 100%; }
    .login-card-inner { padding: 1.5rem; }
    .logo-text h1 { font-size: 1.35rem; }
    .logo-icon { width: 42px; height: 42px; font-size: 1.15rem; }
    .orb-1 { width: 300px; height: 300px; }
    .orb-2 { width: 220px; height: 220px; }
    .orb-3 { display: none; }

    .chat-header { padding: 0 0.65rem; height: 52px; }
    .brand-icon { width: 28px; height: 28px; font-size: .75rem; }
    .user-avatar { width: 28px; height: 28px; font-size: 0.72rem; }
    .icon-btn { width: 30px; height: 30px; font-size: 0.75rem; }
    .admin-panel-btn { padding: .3rem .65rem; font-size: .7rem; }
    .admin-panel-btn span { display: none; }

    .rooms-navbar { height: 42px; }
    .navbar-content { gap: 0.25rem; }
    .main-room-tag, .room-tag, .private-chat-tag { padding: .25rem .65rem; font-size: .72rem; }

    .sidebar-content { padding: 0.6rem; }
    .private-chat-item, .user-item { padding: 0.5rem 0.6rem; }
    .private-chat-avatar, .user-item-avatar { width: 32px; height: 32px; font-size: 0.72rem; }

    .message { max-width: 94%; }
    .message-content { font-size: 0.84rem; }
    .message.own, .message.other { padding: .55rem .75rem; }

    .message-input-container { padding: .55rem .65rem; }
    .input-wrapper { border-radius: var(--r); }
    .send-btn { width: 32px; height: 32px; font-size: .72rem; }

    .fab-btn { width: 44px; height: 44px; font-size: 1rem; }
    .mobile-fab { bottom: 1.2rem; right: 0.85rem; gap: .5rem; }

    .modal-container { border-radius: var(--r); }
    .modal-header { padding: .85rem 1rem; }
    .modal-header h2 { font-size: .9rem; }
    .modal-content { padding: .85rem; }
    .modal-footer { padding: .7rem 1rem; }
    .rooms-grid { grid-template-columns: 1fr 1fr; gap: 0.55rem; }
    .room-card { padding: 0.75rem; }

    .profile-modal { max-width: 92vw; }
    .profile-card-header { padding: 24px 16px 16px; }
    .profile-avatar { width: 68px; height: 68px; font-size: 1.6rem; }
    .profile-display-name { font-size: 1.15rem; }
    .profile-card-body { padding: 12px 14px 6px; max-height: 220px; }
    .profile-card-footer { padding: 8px 12px 12px; gap: 5px; }
    .profile-btn { padding: 8px 6px; font-size: .74rem; }
    .profile-admin-actions .btn-action { font-size: .72rem; padding: 7px 5px; }

    .stats-grid, .stats-grid-mini { grid-template-columns: 1fr 1fr; }

    /* Header del admin: UNA fila limpia. Título compacto a la izquierda y las
       acciones (Actualizar/Cerrar) como botones de icono redondos a la derecha
       (antes se apilaba con dos botones estirados, se veía mal). */
    .admin-panel-header {
        flex-direction: row; align-items: center; flex-wrap: nowrap;
        gap: 8px; padding: 0 12px; height: 54px;
    }
    .admin-panel-header h1 {
        font-size: 1rem; gap: .45rem; min-width: 0; flex: 1;
        overflow: hidden; white-space: nowrap; text-overflow: ellipsis;
    }
    .admin-panel-actions { width: auto; flex-shrink: 0; gap: 6px; }
    .admin-panel-actions .btn-admin {
        font-size: 0; width: 38px; height: 38px; padding: 0;
        border-radius: 50%; justify-content: center; flex: 0 0 auto;
    }
    .admin-panel-actions .btn-admin i { font-size: .95rem; }

    .admin-dashboard-grid { grid-template-columns: 1fr; }
    .admin-filter-btn { padding: .28rem .6rem; font-size: .7rem; }

    .pp-modal { width: 98vw; }
    .ct-emoji-picker { width: 280px; }
}

/* ── Very small screens ─────────────────────────── */
@media (max-width: 360px) {
    .login-card-inner { padding: 1.25rem; }
    .logo-text h1 { font-size: 1.2rem; }
    .rooms-grid { grid-template-columns: 1fr; }
    .stats-grid { grid-template-columns: 1fr; }
    .profile-card-footer { grid-template-columns: 1fr 1fr; }
    .profile-btn { font-size: .72rem; padding: 7px 4px; }
}

/* ── Landscape on short screens ─────────────────── */
@media (max-height: 500px) and (orientation: landscape) {
    .chat-header { height: 48px; }
    .rooms-navbar { display: none; }
    .messages-container { padding: 0.5rem 1rem; }
    .message-input-container { padding: .5rem .75rem; }
    .mobile-fab { bottom: 0.5rem; right: 0.75rem; }
    .fab-btn { width: 38px; height: 38px; font-size: 0.85rem; }

    .login-container {
        align-items: flex-start;
        overflow-y: auto;
        padding-top: 0.75rem;
    }
    .login-card { max-width: 380px; margin: 0 auto; }
    .login-card-inner { padding: 1.25rem; }
    .orb-1, .orb-2, .orb-3 { display: none; }
}

/* ── Safe area insets (notch/home bar) ──────────── */
@supports (padding: max(0px)) {
    .chat-container {
        padding-left: env(safe-area-inset-left);
        padding-right: env(safe-area-inset-right);
    }
    .mobile-fab {
        bottom: max(1.25rem, env(safe-area-inset-bottom));
        right: max(1.2rem, env(safe-area-inset-right));
    }
    .message-input-container {
        padding-bottom: max(0.75rem, env(safe-area-inset-bottom));
    }
}

/* ── Hover capability detection ─────────────────── */
@media (hover: none) {
    /* En táctil no se usa la flechita; el menú se abre tocando el nombre. */
    .msg-menu-trigger { display: none !important; }
    .sidebar-room-close { opacity: 1; }
    .private-chat-item:hover,
    .user-item:hover { transform: none; }
    .room-card:hover { transform: none; }
    .admin-user-card:hover,
    .admin-report-card:hover { transform: none; }
}

/* ── Reduced motion preference ──────────────────── */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    .orb-1, .orb-2, .orb-3 { animation: none; }
}

/* ── High contrast mode ─────────────────────────── */
@media (prefers-contrast: high) {
    :root {
        --border: rgba(255, 255, 255, 0.15);
        --text-muted: #6b7280;
    }
    .message.own { box-shadow: 0 0 0 1px rgba(255,255,255,.2); }
    .message.other { border-width: 2px; }
}

/* ── Panel de administración en móvil (pasada a fondo) ───────────────────────
   La base ya adapta nav→barra horizontal y apila secciones; aquí se corrigen
   los desbordes finos: búsquedas, tablas anchas, acciones del header y nav. */
@media (max-width: 768px) {
    /* La barra de navegación no deja un hueco grande al final (margin-left:auto)
       que obligaba a hacer scroll sobre vacío. */
    .admin-nav-section:last-child .admin-nav-item { margin-left: 0; }
    /* La tabla de mensajes (debug) se desliza en horizontal sin romper la página
       y mantiene columnas legibles en vez de aplastarse. */
    .messages-table { -webkit-overflow-scrolling: touch; }
    .messages-table table { min-width: 600px; }
}
@media (max-width: 600px) {
    /* Las búsquedas internas (Usuarios, Reportes, Categorías) tienen min-width
       inline de 240-260px: aquí ocupan el ancho disponible y no desbordan. */
    .admin-main-actions { width: 100%; }
    .admin-main-actions .admin-search { min-width: 0 !important; width: 100%; }
    /* (Las acciones del header del panel ahora son iconos redondos: ver bloque
       principal arriba; no se estiran a todo el ancho.) */
    /* Filtros y sub-pestañas de moderación se desplazan en lugar de cortarse. */
    .mod-groups { flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .mod-group { flex-shrink: 0; }
}
@media (max-width: 480px) {
    /* El título sin la insignia "EN VIVO" (ocupa espacio); el punto basta. */
    .admin-live-badge { font-size: 0 !important; padding: 0 !important; margin-left: .3rem; background: none !important; border: none !important; }
    .admin-panel-header h1 { font-size: .95rem; }
    /* Navegación compacta tipo "pills": solo icono (+ contador), salvo la activa. */
    .admin-nav { padding: .4rem .5rem; gap: .35rem; }
    .admin-nav-item span:not(.nav-count) { display: none; }
    .admin-nav-item.active span:not(.nav-count) { display: inline; }
    .admin-nav-item { padding: .5rem .7rem; gap: .35rem; border-radius: 999px; }
    .admin-nav-item.active { border-bottom-color: transparent !important; background: var(--primary-dim); }
    .nav-count { margin-left: .2rem; }
    .admin-main-header { padding: .65rem .8rem; }
    .admin-sections { padding: .8rem; }
}

/* ── Perfil en móvil: la portada (cover) usa height fijo con !important en
   style.css (300px), que ganaba sobre las reducciones móviles. responsive.css
   carga después: aquí se fija la altura correcta por dispositivo. ───────────── */
@media (max-width: 768px) {
    /* Portada hero alta (abarca avatar+nombre+botones superpuestos). */
    .pfp-cover, .pfp-cover-hero { height: 260px !important; min-height: 0 !important; }
    /* El perfil de 3/2 columnas se apila para que no se corte ninguna columna */
    .pfp-three-col, .pfp-two-col { grid-template-columns: 1fr !important; }
}
@media (max-width: 480px) {
    .pfp-cover, .pfp-cover-hero { height: 220px !important; }
    .pfp-avatar-lg { width: 84px !important; height: 84px !important; }
    /* La cabecera del perfil sobre la portada no se sale por los lados */
    .pfp-profile-header { padding-left: 12px; padding-right: 12px; flex-wrap: wrap; }
}
