/* DL Directorio Local v0.9.9 (compatibilidad PHP 5.6) */
.dl-directory{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
@media (max-width:1024px){.dl-directory{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.dl-directory{grid-template-columns:1fr}}
.dl-card{border:1px solid #e5e7eb;padding:1rem;text-align:center;border-radius:12px;position:relative;background:#fff;box-shadow:0 2px 6px rgba(0,0,0,.04)}
.dl-avatar{width:200px;height:200px;border-radius:50% !important;overflow:hidden;display:inline-block;line-height:0;margin:0 auto}
.dl-avatar img{width:100% !important;height:100% !important;max-width:none !important;aspect-ratio:1/1;object-fit:cover !important;border-radius:50% !important;display:block}
.dl-avatar--placeholder{width:200px;height:200px;border-radius:50%;background:#f2f2f2;margin:0 auto}
.dl-infoicon{position:absolute;top:10px;right:10px;width:38px;height:38px;border-radius:50%;background:#1976d2;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;font-weight:700;z-index:2}
.dl-name{margin:.75rem 0;font-size:1.1rem}
.dl-attr{margin:.25rem 0}
.dl-btn{background:var(--dl-primary,#d32f2f);color:#fff;padding:.5rem 1rem;border:none;border-radius:8px;cursor:pointer}
.dl-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:9999}
.dl-modal__dialog{background:#fff;margin:5% auto;max-width:560px;padding:1.25rem;border-radius:12px;position:relative}
.dl-modal__close{position:absolute;top:10px;right:10px;width:56px;height:56px;border-radius:50%;background:#1976d2;color:#fff;border:none;cursor:pointer;font-size:26px;display:flex;align-items:center;justify-content:center;line-height:1}
.dl-form input[type=text],.dl-form input[type=email],.dl-form input[type=password],
.dl-form-contact input[type=text],.dl-form-contact input[type=email],.dl-form-contact textarea,
.dl-profile-form input[type=text],.dl-profile-form input[type=email],.dl-profile-form textarea,.dl-profile-form select{width:100%;max-width:520px;padding:.5rem;border:1px solid #e5e7eb;border-radius:8px}
.dl-form p,.dl-form-contact p,.dl-profile-form p{margin:.75rem 0}
.dl-alert{background:#fff3cd;border:1px solid #ffe58f;padding:.75rem 1rem;border-radius:8px}
.dl-notice{background:#e7f5ff;border:1px solid #a5d8ff;padding:.75rem 1rem;border-radius:8px}
.dl-contact-form{margin-top:.5rem;text-align:left}
.dl-filter{display:flex;gap:.5rem;align-items:center;margin-bottom:1rem;flex-wrap:wrap}
.dl-filter select{padding:.5rem;border:1px solid #e5e7eb;border-radius:8px}
#dl-double-search{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}
#dl-double-search select{padding:.5rem;border:1px solid #e5e7eb;border-radius:8px}
