/* ---------- VARIABLES CLARAS ---------- */
:root {
    --dap-primary:       #E42620; /* Rojo principal */
    --dap-primary-dark:  #C11E1A;
    --dap-primary-rgb:   228, 38, 32;
    --dap-text-main:     #666666; /* Plomo para el texto */
    --dap-text-muted:    #888888; /* Plomo m¨¢s claro */
    --dap-text-on-primary: #FFFFFF; /* Blanco */
    --dap-border-soft:   #DDDDDD;
    --dap-bg-card:       #FFFFFF; /* Fondo Blanco */
    --dap-bg-page:       #FFFFFF; /* Fondo Blanco */
    --dap-bg-chip:       #F9F9F9;
    --dap-bg-field-hover: #F9F9F9;
    --dap-card-border:   rgba(0,0,0,0.08);
    --dap-radius-card:   12px;
    --dap-radius-pill:   999px;
    --dap-shadow-card:   0 4px 18px rgba(0,0,0,0.07);
    --dap-shadow-hover:  0 8px 28px rgba(0,0,0,0.12);
    --dap-font:          'Montserrat', system-ui, sans-serif;
    --dap-transition:    0.3s ease;
}

/* ---------- RESET Y CONTENEDOR ---------- */
.dap-app-wrapper *, .dap-single-artesano * { box-sizing: border-box; }
.dap-app-wrapper, .dap-single-artesano, .dap-app-wrapper p, .dap-single-artesano p { font-family: var(--dap-font); color: var(--dap-text-main); }
.dap-app-wrapper { max-width: 1200px; margin: 0 auto; padding: 1.5rem 1rem; background-color: var(--dap-bg-page); }

/* ---------- BARRA DE FILTROS ---------- */
.dap-filtros-bar { display: flex; flex-wrap: wrap; gap: 1rem; margin-bottom: 1.8rem; }
.dap-filtro-item { flex: 1 1 220px; display: flex; flex-direction: column; gap: 4px; }
.dap-filtro-item label { font-size: 0.78rem; font-weight: 600; text-transform: uppercase; color: var(--dap-text-muted); }
.dap-filtro-item input, .dap-filtro-item select { width: 100%; min-height: 42px; padding: 0.5rem 1rem; border-radius: var(--dap-radius-pill); border: 1.5px solid var(--dap-border-soft); font-size: 0.88rem; color: var(--dap-text-main); background: var(--dap-bg-card); transition: var(--dap-transition); }
.dap-filtro-item input:focus, .dap-filtro-item select:focus { outline: none; border-color: var(--dap-primary); }

/* ---------- GRID DE 4 COLUMNAS (Desktop) ---------- */
.dap-grid-artesanos, .dap-grid-productos, .dap-single-productos-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.2rem;
}

/* ---------- CARDS ---------- */
.dap-card-artesano, .dap-card-producto { background: var(--dap-bg-card); border: 1px solid var(--dap-card-border); border-radius: var(--dap-radius-card); overflow: hidden; box-shadow: var(--dap-shadow-card); display: flex; flex-direction: column; transition: var(--dap-transition); cursor: pointer; }
.dap-card-artesano:hover, .dap-card-producto:hover { border-color: rgba(var(--dap-primary-rgb), 0.3); transform: translateY(-4px); box-shadow: var(--dap-shadow-hover); }

/* Efecto Hover Zoom en la imagen del producto */
.dap-card-img-wrapper { width: 100%; padding-top: 75%; position: relative; overflow: hidden; }
.dap-card-img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-size: cover; background-position: center; transition: transform 0.4s ease; }
.dap-card-producto:hover .dap-card-img { transform: scale(1.1); }

.dap-card-cover { width: 100%; padding-top: 46%; background-size: cover; background-position: center; }
.dap-card-header { display: flex; align-items: center; gap: 0.75rem; padding: 0.85rem 1rem 0.3rem; }
.dap-avatar { width: 56px; height: 56px; border-radius: 50%; background-size: cover; border: 2px solid var(--dap-bg-card); flex-shrink: 0; }
.dap-card-header-text h3, .dap-card-producto h3 { font-size: 1rem; font-weight: 700; margin: 0 0 0.2rem; color: var(--dap-primary); }
.dap-badge-cat, .dap-badge-place { font-size: 0.75rem; margin: 0; color: var(--dap-text-muted); }
.dap-card-body { padding: 0.8rem 1rem; font-size: 0.85rem; flex: 1; }
.dap-line { margin: 0.2rem 0; color: var(--dap-text-main); }
.dap-card-footer { padding: 0.7rem 1rem 1rem; display: flex; justify-content: center; }

/* ---------- BOTONES ---------- */
.dap-btn-primary { width: 100%; font-size: 0.85rem; font-weight: 700; padding: 0.6rem 1.1rem; border-radius: var(--dap-radius-pill); background: var(--dap-primary); color: var(--dap-text-on-primary); text-decoration: none; text-align: center; border: none; cursor: pointer; transition: var(--dap-transition); }
.dap-btn-primary:hover { background: var(--dap-primary-dark); color: #fff; }

/* ---------- POPUP / MODAL ---------- */
.dap-modal { display: none; position: fixed; z-index: 9999; left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.6); backdrop-filter: blur(4px); align-items: center; justify-content: center; }
.dap-modal.show { display: flex; }
.dap-modal-content { background-color: var(--dap-bg-card); padding: 2rem; border-radius: var(--dap-radius-card); max-width: 700px; width: 90%; position: relative; box-shadow: 0 10px 40px rgba(0,0,0,0.2); animation: dapModalFadeIn 0.3s ease; }
@keyframes dapModalFadeIn { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.dap-modal-close { position: absolute; top: 15px; right: 20px; color: var(--dap-text-muted); font-size: 28px; font-weight: bold; cursor: pointer; transition: var(--dap-transition); }
.dap-modal-close:hover { color: var(--dap-primary); }
.dap-modal-body { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.dap-modal-img { width: 100%; padding-top: 100%; background-size: cover; background-position: center; border-radius: 8px; border: 1px solid var(--dap-border-soft); }
.dap-modal-info h3 { font-size: 1.5rem; color: var(--dap-primary); margin-top: 0; margin-bottom: 1rem; }

/* ---------- SINGLE ARTESANO ---------- */
.dap-single-artesano { max-width: 960px; margin: 0 auto; padding: 1.5rem 1rem 3rem; background: var(--dap-bg-page); }
.dap-back-link { font-weight: 600; color: var(--dap-text-muted); text-decoration: none; margin-bottom: 1rem; display: inline-block; }
.dap-single-cover { width: 100%; height: 250px; border-radius: 18px; background-size: cover; background-position: center; margin-bottom: 1.4rem; }
.dap-single-header { display: flex; align-items: center; gap: 1.2rem; margin-bottom: 2rem; }
.dap-single-avatar { width: 100px; height: 100px; border-radius: 50%; background-size: cover; border: 4px solid var(--dap-bg-card); }
.dap-single-header h1 { font-size: 2rem; color: var(--dap-primary); margin: 0; }
.dap-single-grid { display: grid; grid-template-columns: 1.6fr 1.2fr; gap: 1.5rem; margin-bottom: 2rem; }
.dap-single-card { background: var(--dap-bg-card); padding: 1.5rem; border-radius: var(--dap-radius-card); box-shadow: var(--dap-shadow-card); border: 1px solid var(--dap-card-border); }
.dap-single-card h2 { color: var(--dap-primary); font-size: 1.1rem; border-bottom: 2px solid var(--dap-border-soft); padding-bottom: 0.5rem; margin-top:0; }
.dap-chip-link { display: inline-block; padding: 0.3rem 0.8rem; border-radius: 20px; background: var(--dap-bg-chip); color: var(--dap-text-main); text-decoration: none; font-size: 0.8rem; margin: 0.2rem; border: 1px solid var(--dap-border-soft); }
.dap-chip-link:hover { background: var(--dap-primary); color: #fff; }

/* ---------- AJUSTE DE ESPACIOS EN LA FICHA ---------- */

/* Párrafos dentro de las cards (info + contacto) — espacio mínimo */
.dap-single-card p {
    margin: 0 0 0.45rem 0 !important;
    line-height: 1.5 !important;
    padding: 0 !important;
}
.dap-single-card p:last-child {
    margin-bottom: 0 !important;
}

/* Párrafos de biografía — mantienen algo más de respiro */
.dap-single-content p {
    margin: 0 0 0.85rem 0 !important;
    line-height: 1.65 !important;
}
.dap-single-content p:last-child {
    margin-bottom: 0 !important;
}

/* Taller / Lugar — alta especificidad para ganarle al tema */
.dap-single-artesano .dap-single-sub,
.dap-single-artesano p.dap-single-sub {
    margin: 0 0 0.2rem 0 !important;
    line-height: 1.4 !important;
    padding: 0 !important;
    font-size: 0.9rem !important;
    color: var(--dap-text-main) !important;
}
.dap-single-artesano .dap-single-sub:last-child,
.dap-single-artesano p.dap-single-sub:last-child {
    margin-bottom: 0 !important;
}

/* Header text — eliminar cualquier margen de hijo que el tema añada */
.dap-single-artesano .dap-single-header-text > * {
    margin-top: 0 !important;
}

/* Chip de categoría — alta especificidad para ganarle al tema */
.dap-single-artesano .dap-single-chip,
.dap-single-artesano span.dap-single-chip {
    display: inline-block !important;
    margin: 0 0 0.35rem 0 !important;
    padding: 0.2rem 0.8rem !important;
    border-radius: 99px !important;
    background: var(--dap-primary) !important;
    background-color: var(--dap-primary) !important;
    color: #ffffff !important;
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    line-height: 1.6 !important;
    text-decoration: none !important;
    border: none !important;
}

/* Botón WhatsApp en ficha */
.dap-btn-whatsapp {
    display: inline-block !important;
    margin-top: 0.8rem;
}

/* Redes sociales en ficha — sin espacio extra del tema */
.dap-single-social {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-top: 0.8rem;
}

/* Chip-links (Facebook, Instagram, etc.) — quitar margen del tema */
.dap-single-artesano .dap-chip-link {
    margin: 0 !important;
    padding: 0.3rem 0.8rem !important;
}

/* Mapa en ficha */
.dap-single-mapa {
    margin-top: 1.2rem;
}

/* Contenido / Biografía */
.dap-single-content {
    margin-top: 0.8rem;
}

/* Encabezado Productos del artesano */
.dap-productos-titulo {
    font-size: 1.2rem;
    font-weight: bold;
    color: var(--dap-primary);
    border-bottom: 2px solid var(--dap-border-soft);
    padding-bottom: 0.5rem;
    margin-bottom: 1.5rem;
}

/* ---------- RESPONSIVE GRID (2 Columnas en M¨®vil) ---------- */
@media (max-width: 768px) {
    .dap-grid-artesanos, .dap-grid-productos, .dap-single-productos-grid { grid-template-columns: repeat(2, 1fr); }
    .dap-modal-body { grid-template-columns: 1fr; }
    .dap-single-grid { grid-template-columns: 1fr; }
}