Для
p тогда надо поставить display: inline-block;
Цитата:
|
Строчные элементы являются потомками блочных элементов. Они игнорируют верхние и нижние margin и padding, но если для элемента задан фон, он будет распространяться на верхний и нижний padding, заходя на соседние строки текста.
|
Рекомендую к прочтению:
https://html5book.ru/block-inline-elements/
Особенно про схлопывание