/* ============================================================
 * DP UI Pack — 17 Sidebar widgets (v2 simplifié)
 * Cible : aside#secondary.blog-sidebar > .widget (additif uniquement)
 * Ne touche PAS .blog-sidebar-wrapper / .col-md-3
 * ============================================================ */

/* Stack des widgets */
aside#secondary.blog-sidebar {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  font-family: var(--dp-font);
  color: var(--dp-text);
  font-size: 1rem;
}

/* Card par widget */
aside#secondary.blog-sidebar > .widget {
  background: var(--dp-bg);
  border: 1px solid var(--dp-border);
  border-radius: var(--dp-radius);
  padding: 1.15rem 1.2rem;
  box-shadow: var(--dp-shadow-xs);
  margin: 0;
  transition: box-shadow var(--dp-tr), border-color var(--dp-tr);
  font-size: 1rem;
}
aside#secondary.blog-sidebar > .widget:hover {
  box-shadow: var(--dp-shadow-sm);
  border-color: var(--dp-border-strong);
}
aside#secondary.blog-sidebar > .widget_media_image { padding: 0.5rem; }

/* Titres */
aside#secondary.blog-sidebar > .widget h2,
aside#secondary.blog-sidebar > .widget h3,
aside#secondary.blog-sidebar > .widget .widget-title {
  font-family: var(--dp-font-h);
  font-size: 1.02rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--dp-text-strong);
  margin: 0 0 0.8rem;
  padding: 0 0 0.55rem;
  border-bottom: 1px solid var(--dp-border);
  letter-spacing: -0.005em;
}

/* Paragraphes */
aside#secondary.blog-sidebar > .widget p {
  margin: 0 0 0.65rem;
  font-size: 0.98rem;
  line-height: 1.6;
  color: var(--dp-text);
}
aside#secondary.blog-sidebar > .widget p:last-child { margin-bottom: 0; }
aside#secondary.blog-sidebar > .widget strong { color: var(--dp-text-strong); }

/* Adresse */
aside#secondary.blog-sidebar > .widget p.adr {
  background: var(--dp-bg-soft);
  border: 1px solid var(--dp-border);
  border-radius: var(--dp-radius-sm);
  padding: 0.7rem 0.85rem 0.7rem 2rem;
  margin: 0.6rem 0 0.85rem;
  font-size: 0.94rem;
  line-height: 1.55;
  color: var(--dp-text);
  position: relative;
}
aside#secondary.blog-sidebar > .widget p.adr::before {
  content: "📍";
  position: absolute;
  left: 0.65rem;
  top: 0.6rem;
  font-size: 1rem;
  line-height: 1;
}
aside#secondary.blog-sidebar > .widget p.adr .street-address { display: inline; }
aside#secondary.blog-sidebar > .widget p.adr .street-address:first-child strong {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--dp-primary-dark);
  margin-right: 0.25rem;
}

/* Bloc tel/mobile/email empilé */
aside#secondary.blog-sidebar > .widget p:has(> .tel) {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.04), rgba(239, 68, 68, 0.08));
  border: 1px solid rgba(239, 68, 68, 0.15);
  border-radius: var(--dp-radius-sm);
  padding: 0.8rem 0.85rem;
  margin: 0.6rem 0 0.85rem;
}
aside#secondary.blog-sidebar > .widget p:has(> .tel) br { display: none; }

/* Pills tel/mobile/email — !important nécessaire pour battre les couleurs Hestia/global qui s'appliquent aux <strong> et <a> imbriqués */
aside#secondary.blog-sidebar > .widget .tel,
aside#secondary.blog-sidebar > .widget .email {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  padding: 0.6rem 1rem;
  font-size: 0.98rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: var(--dp-radius-pill);
  white-space: nowrap;
  transition: transform var(--dp-tr-fast), box-shadow var(--dp-tr-fast), background var(--dp-tr-fast), color var(--dp-tr-fast);
}
aside#secondary.blog-sidebar > .widget .tel {
  background: linear-gradient(135deg, var(--dp-primary), var(--dp-primary-dark)) !important;
  color: #fff !important;
  box-shadow: var(--dp-shadow-red);
}
aside#secondary.blog-sidebar > .widget .tel::before { content: "📞"; }
aside#secondary.blog-sidebar > .widget .tel,
aside#secondary.blog-sidebar > .widget .tel strong,
aside#secondary.blog-sidebar > .widget .tel * { color: #fff !important; font-weight: 700; }
aside#secondary.blog-sidebar > .widget .tel:hover { transform: translateY(-1px); box-shadow: 0 12px 28px rgba(239, 68, 68, 0.32); }
aside#secondary.blog-sidebar > .widget .tel.mobile {
  background: #fff !important;
  color: var(--dp-primary-dark) !important;
  border: 1.5px solid var(--dp-primary);
  box-shadow: 0 2px 8px rgba(239, 68, 68, 0.12);
}
aside#secondary.blog-sidebar > .widget .tel.mobile::before { content: "📱"; }
aside#secondary.blog-sidebar > .widget .tel.mobile,
aside#secondary.blog-sidebar > .widget .tel.mobile strong,
aside#secondary.blog-sidebar > .widget .tel.mobile * { color: var(--dp-primary-dark) !important; }
aside#secondary.blog-sidebar > .widget .tel.mobile:hover,
aside#secondary.blog-sidebar > .widget .tel.mobile:hover *,
aside#secondary.blog-sidebar > .widget .tel.mobile:hover strong { background: var(--dp-primary) !important; color: #fff !important; }
aside#secondary.blog-sidebar > .widget .email {
  background: var(--dp-bg-soft);
  color: var(--dp-text) !important;
  border: 1px solid var(--dp-border-strong);
  font-size: 0.92rem;
  word-break: break-all;
}
aside#secondary.blog-sidebar > .widget .email::before { content: "✉"; }
aside#secondary.blog-sidebar > .widget .email strong { color: var(--dp-text) !important; }
aside#secondary.blog-sidebar > .widget .email a { color: var(--dp-primary-dark) !important; text-decoration: none; font-weight: 600; }
aside#secondary.blog-sidebar > .widget .email a:hover { color: var(--dp-primary) !important; }

/* SIRET pill */
aside#secondary.blog-sidebar > .widget .siret {
  display: inline-block;
  font-size: 0.84rem;
  color: var(--dp-text-muted);
  background: var(--dp-bg-mid);
  padding: 0.3rem 0.7rem;
  border-radius: var(--dp-radius-pill);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}
aside#secondary.blog-sidebar > .widget .siret strong {
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--dp-text-muted);
  margin-right: 0.3rem;
}

/* Liens p */
aside#secondary.blog-sidebar > .widget p a {
  color: var(--dp-primary-dark);
  text-decoration: none;
  font-weight: 600;
  border-bottom: 1px solid transparent;
  transition: color var(--dp-tr-fast), border-color var(--dp-tr-fast);
}
aside#secondary.blog-sidebar > .widget p a:hover {
  color: var(--dp-primary);
  border-bottom-color: var(--dp-primary);
}

/* Images media widgets */
aside#secondary.blog-sidebar > .widget_media_image img,
aside#secondary.blog-sidebar > .widget figure img {
  display: block;
  max-width: 100%;
  height: auto;
  border-radius: var(--dp-radius-sm);
  box-shadow: var(--dp-shadow-xs);
  transition: transform var(--dp-tr), box-shadow var(--dp-tr);
}
aside#secondary.blog-sidebar > .widget_media_image:hover img {
  transform: scale(1.02);
  box-shadow: var(--dp-shadow-sm);
}

/* Mobile */
@media (max-width: 599px) {
  aside#secondary.blog-sidebar > .widget { padding: 1rem; }
  aside#secondary.blog-sidebar > .widget .tel,
  aside#secondary.blog-sidebar > .widget .email { width: 100%; }
}
