/* ============================================================
   general/activities-target.css — box « Activités conseillées » partagée
   Composant autonome scopé sous .activities-target (indépendant du wrapper de
   page : fonctionne sur .hol comme sur .article). Reutilise la palette
   globale de style.css via des variables locales --ha-*.
   ============================================================ */

.activities-target {
    --ha-ink:    var(--color-dark, #1f2937);
    --ha-muted:  var(--color-text-light, #4b5563);
    --ha-faint:  var(--color-grey, #9ca3af);
    --ha-line:   var(--color-light-grey, #e5e7eb);
    --ha-blue-d: var(--color-primary-dark, #2563eb);
    margin-top: clamp(2.25rem, 5vw, 3.25rem);
    font-family: "Roboto", system-ui, sans-serif;
    container-type: inline-size;   /* la grille interne reagit a la largeur de la BOX */
}
.activities-target__title {
    font-size: clamp(1.25rem, 1rem + 1vw, 1.6rem);
    font-weight: 800;
    letter-spacing: -0.01em;
    color: var(--ha-ink);
    margin: 0 0 1.25rem;
}
.activities-target .act-grid {
    display: grid;
    grid-template-columns: 1fr;          /* etroit : 1 colonne */
    gap: 1.25rem;
}
/* Responsive sur la largeur de la BOX (container query) : 2 puis 3 colonnes (1/3) */
@container (min-width: 460px) {
    .activities-target .act-grid { grid-template-columns: repeat(2, 1fr); }
}
@container (min-width: 680px) {
    .activities-target .act-grid { grid-template-columns: repeat(3, 1fr); }
}
/* Repli (navigateurs sans @container) : bascule sur la largeur du viewport */
@supports not (container-type: inline-size) {
    @media (min-width: 560px) { .activities-target .act-grid { grid-template-columns: repeat(2, 1fr); } }
    @media (min-width: 980px) { .activities-target .act-grid { grid-template-columns: repeat(3, 1fr); } }
}
.activities-target .act-card {
    background: #fff;
    border: 1px solid var(--ha-line);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: var(--shadow-sm, 0 1px 6px rgba(0, 0, 0, 0.06));
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
    transition: box-shadow 0.15s ease, transform 0.15s ease;
}
.activities-target .act-card:hover { box-shadow: var(--shadow-md, 0 6px 18px rgba(0, 0, 0, 0.10)); transform: translateY(-2px); }
.activities-target .act-img { width: 100%; aspect-ratio: 16 / 9; overflow: hidden; background: #f0f0f0; }
.activities-target .act-img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.3s; }
.activities-target .act-card:hover .act-img img { transform: scale(1.04); }
.activities-target .act-body { padding: 1rem 1.15rem 1.1rem; display: flex; flex-direction: column; flex: 1; gap: 0.35rem; }
.activities-target .act-location { font-size: 0.75rem; color: var(--ha-faint); text-transform: uppercase; letter-spacing: 0.05em; }
.activities-target .act-title { font-size: 0.95rem; font-weight: 700; color: var(--ha-ink); margin: 0; line-height: 1.35; }
.activities-target .act-organisator { font-size: 0.8rem; color: var(--ha-muted); }
.activities-target .act-rating { display: flex; align-items: center; gap: 0.35rem; font-size: 0.82rem; margin-top: 0.2rem; }
.activities-target .act-stars { font-size: 0.85rem; letter-spacing: 0.03em; }
.activities-target .act-score { font-weight: 700; color: var(--ha-ink); }
.activities-target .act-reviews { color: var(--ha-faint); }
.activities-target .act-footer { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 0.85rem; border-top: 1px solid var(--ha-line); }
.activities-target .act-price { display: flex; flex-direction: column; line-height: 1.2; }
.activities-target .act-price-from { font-size: 0.72rem; color: var(--ha-faint); }
.activities-target .act-price strong { font-size: 1.1rem; font-weight: 700; color: var(--ha-ink); }
.activities-target .act-btn {
    display: inline-flex;
    align-items: center;
    margin-left: auto;
    background: var(--ha-blue-d);
    color: #fff;
    border-radius: 8px;
    padding: 0.45rem 1rem;
    font-size: 0.85rem;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.15s;
    white-space: nowrap;
}
.activities-target .act-btn:hover { background: #1d4ed8; }
.activities-target .star--full { color: #f59e0b; }
.activities-target .star--half { color: #f59e0b; opacity: 0.6; }
.activities-target .star--empty { color: #ddd; }
