:root {
    --primary:       #5c1f52;
    --primary-mid:   #3d1235;
    --primary-light: #7a3570;
    --accent:        #0f766e;
    --accent-light:  #14b8a6;
    --foam:          #f8f9fb;
    --sand:          #dde3ed;
    --text:          #111827;
    --muted:         #6b7280;
    --white:         #ffffff;

    /* Utilisateurs — espacés sur la roue chromatique */
    --fam1-color:  #16a34a; --fam1-bg: #dcfce7; --fam1-border: #86efac;  /* Papy Guy  — vert       */
    --fam2-color:  #c026d3; --fam2-bg: #fdf4ff; --fam2-border: #e879f9;  /* Maud      — fuchsia    */
    --fam3-color:  #65a30d; --fam3-bg: #f7fee7; --fam3-border: #bef264;  /* Flo       — lime       */
    --fam4-color:  #4f46e5; --fam4-bg: #eef2ff; --fam4-border: #a5b4fc;  /* Esther    — indigo     */
    --fam5-color:  #ca8a04; --fam5-bg: #fefce8; --fam5-border: #fde047;  /* Georges   — jaune      */
    --fam6-color:  #0284c7; --fam6-bg: #e0f2fe; --fam6-border: #7dd3fc;  /* Mamy Titi — ciel       */
    --fam7-color:  #dc2626; --fam7-bg: #fee2e2; --fam7-border: #fca5a5;  /* Léna      — rouge      */

    /* Garde unique */
    --garde-color: #065f46; --garde-bg: #047857; --garde-border: #064e3b;

    /* Événement unique */
    --event-color: #c2410c; --event-bg: #ea580c; --event-border: #9a3412;

    --font-display: 'Montserrat', 'Segoe UI', system-ui, sans-serif;
    --font-body:    'Open Sans', system-ui, -apple-system, sans-serif;

    /* ── Échelle typographique secondaire ── */
    --fs-micro:  0.62rem;   /* calendrier : jours fériés, mini labels       */
    --fs-badge:  0.72rem;   /* badges pill : famille, statut, rôle          */
    --fs-meta:   0.78rem;   /* métadonnées : dates, comptes, descriptions   */

    /* ── Couleurs sémantiques (statuts) — centralisées ──
       NB : certaines coïncident avec des couleurs membres, c'est normal. */
    --ok:        #16a34a;  --ok-bg:     #dcfce7;  --ok-text:    #166534;  --ok-border:   #86efac;  /* succès / validé / offert */
    --warn:      #d97706;  --warn-bg:   #fef3c7;  --warn-text:  #92400e;  --warn-border: #fcd34d;  /* attente / quorum manquant */
    --danger:    #dc2626;  --danger-bg: #fee2e2;                          /* erreur / suppression      */
    --info:      #2563eb;  --info-bg:   #dbeafe;                          /* information / souhaité    */
    --select:    #f5e5f0;                                                 /* ton « sélectionné » unique */
}

/* ── Base ── */
body {
    background: var(--foam);
    font-family: var(--font-body);
    color: var(--text);
    -webkit-font-smoothing: antialiased;
}
a { color: var(--primary); text-underline-offset: 3px; }
a:hover { color: var(--primary-mid); }
a.btn, a.nav-link { text-decoration: none; }
h1, h2, .page-title { font-family: var(--font-display); font-weight: 700; color: var(--primary-mid); }
h3, h4, h5, h6 { font-weight: 700; color: var(--primary-mid); }

/* ── Badges : taille unifiée sur toute l'appli ── */
.badge { font-size: var(--fs-badge); font-weight: 700; }

/* ── Boutons Bootstrap : primary → terracotta, pas de rouge parasite ── */
.btn-primary {
    --bs-btn-bg:                  var(--accent);
    --bs-btn-border-color:        var(--accent);
    --bs-btn-hover-bg:            var(--accent-light);
    --bs-btn-hover-border-color:  var(--accent-light);
    --bs-btn-active-bg:           #4e7055;
    --bs-btn-active-border-color: #4e7055;
    --bs-btn-focus-shadow-rgb:    95,138,106;
}
.btn-outline-primary {
    --bs-btn-color:               var(--accent);
    --bs-btn-border-color:        var(--accent);
    --bs-btn-hover-bg:            var(--accent);
    --bs-btn-hover-border-color:  var(--accent);
    --bs-btn-active-bg:           var(--accent);
    --bs-btn-active-border-color: var(--accent);
}

/* ── Header 1 ligne ── */
.site-header-top {
    background: linear-gradient(135deg, var(--primary-mid) 0%, var(--primary) 100%);
    color: white;
    box-shadow: 0 2px 10px rgba(0,0,0,0.2);
}
/* Conteneur flex 1 ligne — toutes pages sauf accueil */
.site-header-inner {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 52px;
    padding: .35rem 0;
}
.site-header-left {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    min-width: 0;
}
.site-header-right {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}
/* Conteneur grid 3 colonnes — page accueil uniquement */
.site-header-home {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    min-height: 52px;
    padding: .35rem 0;
}
.site-header-home-left  { display: flex; align-items: center; }
.site-header-home-right { display: flex; align-items: center; justify-content: flex-end; gap: 6px; }
/* Marque LuMaMaTe (accueil, centre) */
.site-app-name {
    font-family: var(--font-display);
    font-size: 1.3rem;
    font-weight: 800;
    color: #fff;
    letter-spacing: -.02em;
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 4px;
}
.site-app-name .site-logo { height: 28px; }
/* Chip utilisateur (accueil, gauche) — initiales seulement */
.site-user-chip {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: .68rem;
    font-weight: 800;
    color: #fff;
    flex-shrink: 0;
    text-decoration: none;
    border: 2px solid rgba(255,255,255,0.35);
    transition: border-color .15s;
}
.site-user-chip:hover { border-color: rgba(255,255,255,0.75); }
/* Titre de page (autres pages, gauche) */
.site-page-title {
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-weight: 800;
    color: #fff;
    display: flex;
    align-items: center;
    gap: 7px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    letter-spacing: -.01em;
}
.site-page-title .bi { opacity: .82; font-size: 1rem; }
/* Boutons header */
.site-header-btn {
    width: 34px;
    height: 34px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    padding: 0 !important;
    font-size: .9rem !important;
    border-radius: 8px !important;
    flex-shrink: 0;
}
/* Ancien .site-title conservé pour compatibilité login/reset */
.site-title {
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-weight: 700;
    color: white;
}
.site-logo { height: 32px; width: auto; vertical-align: middle; margin-right: 8px; filter: brightness(0) invert(1); }
.login-logo { filter: none; }
.site-title-icon {
    font-size: 1.25em;
    vertical-align: -0.15em;
    margin-right: 0.4rem;
    opacity: 0.92;
}
.site-header-top .btn-outline-light {
    border-color: rgba(255,255,255,0.35);
    color: rgba(255,255,255,0.9);
    font-size: 0.8rem;
}
.site-header-top .btn-outline-light:hover {
    background: rgba(255,255,255,0.12);
    color: #fff;
}
/* Bouton logout dans le header — terracotta discret */
.btn-logout {
    border: 1px solid rgba(95,138,106,0.55);
    color: rgba(210,240,215,0.85);
    background: transparent;
    font-size: 0.8rem;
    border-radius: 6px;
    padding: 0.25rem 0.5rem;
    transition: background .15s, border-color .15s;
}
.btn-logout:hover {
    background: rgba(95,138,106,0.3);
    border-color: rgba(95,138,106,0.85);
    color: #fff;
}

/* ── Badge famille dans le header ── */
.fam-badge {
    font-size: 0.7rem;
    font-weight: 600;
    padding: 3px 8px;
    border-radius: 12px;
    vertical-align: middle;
}
.fam-badge.fam-1 { background: var(--fam1-bg); color: var(--fam1-color); }
.fam-badge.fam-2 { background: var(--fam2-bg); color: var(--fam2-color); }
.fam-badge.fam-3 { background: var(--fam3-bg); color: var(--fam3-color); }
.fam-badge.fam-4 { background: var(--fam4-bg); color: var(--fam4-color); }
.fam-badge.fam-5 { background: var(--fam5-bg); color: var(--fam5-color); }
.fam-badge.fam-6 { background: var(--fam6-bg); color: var(--fam6-color); }
.fam-badge.fam-7 { background: var(--fam7-bg); color: var(--fam7-color); }

/* ── Login ── */
.login-body {
    background: linear-gradient(160deg, #3d1235 0%, #5c1f52 55%, #8b4a7e 100%);
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}
.login-wrap {
    width: 100%;
    max-width: 440px;
    margin: 2rem auto;
    padding: 0 1.25rem;
}
.login-logo { max-height: 80px; max-width: 240px; }
.login-app-name {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 800;
    color: white;
    letter-spacing: -0.02em;
}
.login-subtitle {
    font-size: 0.88rem;
    color: rgba(255,255,255,0.75);
    margin-top: 4px;
}
.login-card {
    background: white;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 12px 40px rgba(0,0,0,0.25);
    margin-top: 1.5rem;
}
.login-header {
    background: linear-gradient(135deg, #0f766e 0%, #0369a1 100%);
    color: white;
    padding: 1.5rem 1.5rem 1.2rem;
    text-align: center;
}
.login-icon { font-size: 5.5rem; display: block; margin-bottom: 0.5rem; }
.login-icon-logo {
    display: block;
    margin: 0 auto 0.6rem;
    max-height: 88px;
    width: auto;
}
.login-header h1 {
    font-family: var(--font-display);
    font-size: 1.3rem;
    font-weight: 700;
    color: white;
    margin: 0;
}
.login-body-inner { padding: 1.5rem; }

/* Grille familles login */
.family-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}
.family-btn {
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 0.6rem 0.75rem;
    border-radius: 12px;
    border: 2px solid var(--fam-border, #e2e8f0);
    background: var(--fam-bg, #f8fafc);
    color: var(--fam-color, var(--text));
    font-weight: 700;
    font-size: 0.85rem;
    cursor: pointer;
    transition: all 0.15s;
    font-family: var(--font-body);
    text-align: left;
}
.family-btn:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.12); }
.family-btn.active {
    border-width: 2.5px;
    border-color: var(--fam-color, var(--primary));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--fam-color, var(--primary)) 18%, transparent);
    transform: scale(1.02);
    background: var(--fam-bg, #f8fafc);
}
.family-btn-avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: 0.62rem;
    font-weight: 800;
    color: #fff;
    letter-spacing: -0.01em;
}
.family-btn-name { flex: 1; line-height: 1.2; }
.family-btn-admin { font-size: 0.6rem; opacity: 0.65; flex-shrink: 0; }

/* Avatar utilisateur (profil, liste) */
.user-avatar {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: 1.15rem;
    font-weight: 800;
    color: #fff;
    letter-spacing: -0.02em;
    text-shadow: 0 1px 3px rgba(0,0,0,0.18);
}

/* ── Calendrier ── */
.cal-wrapper {
    background: var(--white);
    border-radius: 12px;
    border: 1px solid var(--sand);
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
.cal-table { border-collapse: collapse; table-layout: fixed; }
.cal-table thead th {
    background: linear-gradient(135deg, var(--primary-mid) 0%, var(--primary) 100%);
    color: rgba(255,255,255,0.85);
    text-align: center;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 0.5rem 0.25rem;
}
.cal-table thead th.cal-weekend { color: rgba(255,255,255,0.5); }
.cal-cell {
    vertical-align: top;
    padding: 0.35rem;
    border: 1px solid var(--sand);
    width: 14.28%;
    height: 88px;
    overflow: hidden;
}
.cal-cell.cal-empty   { background: #fdf5f9; }
.cal-cell.cal-weekend { background: #fdf3f8; }
.cal-cell.cal-today   { background: #fdf1f7; }
.cal-cell.cal-today .cal-day-num {
    background: var(--primary);
    color: #fff;
    border-radius: 50%;
    width: 22px; height: 22px;
    display: inline-flex; align-items: center; justify-content: center;
}
.cal-cell.cal-selected { background: var(--select); outline: 2px solid var(--primary-light); }
.cal-day-header { display: flex; align-items: center; gap: 3px; height: 20px; margin-bottom: 2px; overflow: hidden; flex-wrap: nowrap; }
.cal-day-num { font-size: 0.78rem; font-weight: 600; color: var(--muted); }

/* Événements sur le calendrier */
.cal-ev {
    display: block;
    font-size: 0.7rem;
    font-weight: 600;
    padding: 2px 5px;
    border-radius: 3px;
    margin-bottom: 2px;
    text-decoration: none !important;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    cursor: default;
}
.cal-ev:hover { opacity: 1; }
.cal-ev-spacer { background: transparent !important; border: none !important; pointer-events: none; }

/* Garde (fond plein) */
.cal-garde.fam-1 { background: var(--fam1-bg); color: var(--fam1-color); border-left: 3px solid var(--fam1-color); }
.cal-garde.fam-2 { background: var(--fam2-bg); color: var(--fam2-color); border-left: 3px solid var(--fam2-color); }
.cal-garde.fam-3 { background: var(--fam3-bg); color: var(--fam3-color); border-left: 3px solid var(--fam3-color); }
.cal-garde.fam-4 { background: var(--fam4-bg); color: var(--fam4-color); border-left: 3px solid var(--fam4-color); }
.cal-garde.fam-5 { background: var(--fam5-bg); color: var(--fam5-color); border-left: 3px solid var(--fam5-color); }
.cal-garde.fam-6 { background: var(--fam6-bg); color: var(--fam6-color); border-left: 3px solid var(--fam6-color); }
.cal-garde.fam-7 { background: var(--fam7-bg); color: var(--fam7-color); border-left: 3px solid var(--fam7-color); }

/* Événement — couleur unifiée (les variantes .fam-X restent pour compat mais ne sont plus utilisées) */
.cal-evenement { background: var(--event-bg); color: #fff; border-left: 4px solid var(--event-border); }
.cal-evenement.fam-1 { background: var(--fam1-bg); color: var(--fam1-color); border: 1px dashed var(--fam1-color); border-left: 3px solid var(--fam1-color); }
.cal-evenement.fam-2 { background: var(--fam2-bg); color: var(--fam2-color); border: 1px dashed var(--fam2-color); border-left: 3px solid var(--fam2-color); }
.cal-evenement.fam-3 { background: var(--fam3-bg); color: var(--fam3-color); border: 1px dashed var(--fam3-color); border-left: 3px solid var(--fam3-color); }
.cal-evenement.fam-4 { background: var(--fam4-bg); color: var(--fam4-color); border: 1px dashed var(--fam4-color); border-left: 3px solid var(--fam4-color); }
.cal-evenement.fam-5 { background: var(--fam5-bg); color: var(--fam5-color); border: 1px dashed var(--fam5-color); border-left: 3px solid var(--fam5-color); }
.cal-evenement.fam-6 { background: var(--fam6-bg); color: var(--fam6-color); border: 1px dashed var(--fam6-color); border-left: 3px solid var(--fam6-color); }
.cal-evenement.fam-7 { background: var(--fam7-bg); color: var(--fam7-color); border: 1px dashed var(--fam7-color); border-left: 3px solid var(--fam7-color); }

/* Spanning multi-jours */
.cal-ev-span-start {
    border-radius: 3px 0 0 3px !important;
    margin-right: calc(-0.35rem - 1px);
    position: relative; z-index: 2;
}
.cal-ev-span-mid {
    border-radius: 0 !important;
    margin-left:  calc(-0.35rem - 1px);
    margin-right: calc(-0.35rem - 1px);
    border-left: none !important;
    padding-left: 3px;
    position: relative; z-index: 2;
}
.cal-ev-span-end {
    border-radius: 0 3px 3px 0 !important;
    margin-left: calc(-0.35rem - 1px);
    border-left: none !important;
    padding-left: 3px;
    position: relative; z-index: 2;
}
@media (max-width: 576px) {
    .cal-ev-span-start { margin-right: calc(-0.2rem - 1px); }
    .cal-ev-span-mid   { margin-left: calc(-0.2rem - 1px); margin-right: calc(-0.2rem - 1px); }
    .cal-ev-span-end   { margin-left: calc(-0.2rem - 1px); }
}

/* Légende */
.legend-item { display: inline-flex; align-items: center; gap: 4px; }
.cal-legend {
    display: inline-block;
    width: 14px; height: 14px;
    border-radius: 3px;
    vertical-align: middle;
}
.cal-legend.cal-garde.fam-1    { background: var(--fam1-bg); border: 2px solid var(--fam1-color); }
.cal-legend.cal-garde.fam-2    { background: var(--fam2-bg); border: 2px solid var(--fam2-color); }
.cal-legend.cal-garde.fam-3    { background: var(--fam3-bg); border: 2px solid var(--fam3-color); }
.cal-legend.cal-garde.fam-4    { background: var(--fam4-bg); border: 2px solid var(--fam4-color); }
.cal-legend.cal-garde.fam-5    { background: var(--fam5-bg); border: 2px solid var(--fam5-color); }
.cal-legend.cal-garde.fam-6    { background: var(--fam6-bg); border: 2px solid var(--fam6-color); }
.cal-legend.cal-garde.fam-7    { background: var(--fam7-bg); border: 2px solid var(--fam7-color); }
.cal-legend.cal-evenement { background: var(--event-bg); border: 2px solid var(--event-border); }
.cal-legend.cal-evenement.fam-1 { background: var(--fam1-bg); border: 2px dashed var(--fam1-color); }
.cal-legend.cal-evenement.fam-2 { background: var(--fam2-bg); border: 2px dashed var(--fam2-color); }
.cal-legend.cal-evenement.fam-3 { background: var(--fam3-bg); border: 2px dashed var(--fam3-color); }
.cal-legend.cal-evenement.fam-4 { background: var(--fam4-bg); border: 2px dashed var(--fam4-color); }
.cal-legend.cal-evenement.fam-5 { background: var(--fam5-bg); border: 2px dashed var(--fam5-color); }
.cal-legend.cal-evenement.fam-6 { background: var(--fam6-bg); border: 2px dashed var(--fam6-color); }
.cal-legend.cal-evenement.fam-7 { background: var(--fam7-bg); border: 2px dashed var(--fam7-color); }

/* ── Détail (panneau sous calendrier) ── */
.detail-card {
    background: var(--white);
    border-radius: 12px;
    border: 1px solid var(--sand);
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,0.07);
}
.detail-card.fam-1 { border-top: 4px solid var(--fam1-color); }
.detail-card.fam-2 { border-top: 4px solid var(--fam2-color); }
.detail-card.fam-3 { border-top: 4px solid var(--fam3-color); }
.detail-card.fam-4 { border-top: 4px solid var(--fam4-color); }
.detail-card.fam-5 { border-top: 4px solid var(--fam5-color); }
.detail-card.fam-6 { border-top: 4px solid var(--fam6-color); }
.detail-card.fam-7 { border-top: 4px solid var(--fam7-color); }

.detail-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 1rem 1.25rem;
    background: #fdf5f9;
    border-bottom: 1px solid var(--sand);
}
.detail-icon { font-size: 1.6rem; flex-shrink: 0; }
.detail-card.fam-1 .detail-icon { color: var(--fam1-color); }
.detail-card.fam-2 .detail-icon { color: var(--fam2-color); }
.detail-card.fam-3 .detail-icon { color: var(--fam3-color); }
.detail-card.fam-4 .detail-icon { color: var(--fam4-color); }
.detail-card.fam-5 .detail-icon { color: var(--fam5-color); }
.detail-card.fam-6 .detail-icon { color: var(--fam6-color); }
.detail-card.fam-7 .detail-icon { color: var(--fam7-color); }

.detail-type  { font-size: var(--fs-badge); text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); }
.detail-title { font-weight: 700; font-size: 1rem; color: var(--text); }
.detail-body  { padding: 1.1rem 1.25rem; }
.detail-label { font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); display: block; }

.btn-close-detail {
    background: none; border: none; color: var(--muted); font-size: 1rem; cursor: pointer; padding: 4px;
    border-radius: 50%; transition: background .15s;
    display: flex; align-items: center; justify-content: center;
}
.btn-close-detail:hover { background: var(--sand); color: var(--text); }

/* ── Liste du mois ── */
a.list-item {
    transition: transform .12s, box-shadow .12s, background .12s;
}
a.list-item:hover {
    transform: translateX(3px);
    background: var(--foam);
    box-shadow: 0 3px 12px rgba(61,18,53,0.10);
    color: inherit;
}
.list-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0.55rem 0.75rem;
    background: var(--white);
    border: 1px solid var(--sand);
    border-radius: 8px;
    overflow: hidden;
}
.list-item.fam-1 { border-left: 4px solid var(--fam1-color); }
.list-item.fam-2 { border-left: 4px solid var(--fam2-color); }
.list-item.fam-3 { border-left: 4px solid var(--fam3-color); }
.list-item.fam-4 { border-left: 4px solid var(--fam4-color); }
.list-item.fam-5 { border-left: 4px solid var(--fam5-color); }
.list-item.fam-6 { border-left: 4px solid var(--fam6-color); }
.list-item.fam-7 { border-left: 4px solid var(--fam7-color); }
.list-item-selected { background: var(--select); }
.list-item-title { color: var(--text); }
.list-item-dot {
    width: 10px; height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}
.list-item-dot.cal-garde.fam-1 { background: var(--fam1-color); }
.list-item-dot.cal-garde.fam-2 { background: var(--fam2-color); }
.list-item-dot.cal-garde.fam-3 { background: var(--fam3-color); }
.list-item-dot.cal-garde.fam-4 { background: var(--fam4-color); }
.list-item-dot.cal-garde.fam-5 { background: var(--fam5-color); }
.list-item-dot.cal-garde.fam-6 { background: var(--fam6-color); }
.list-item-dot.cal-garde.fam-7 { background: var(--fam7-color); }
.list-item-dot.cal-evenement { background: var(--event-bg); border: 2px solid var(--event-color); }
.list-item-dot.cal-evenement.fam-1 { background: var(--fam1-bg); border: 2px solid var(--fam1-color); }
.list-item-dot.cal-evenement.fam-2 { background: var(--fam2-bg); border: 2px solid var(--fam2-color); }
.list-item-dot.cal-evenement.fam-3 { background: var(--fam3-bg); border: 2px solid var(--fam3-color); }
.list-item-dot.cal-evenement.fam-4 { background: var(--fam4-bg); border: 2px solid var(--fam4-color); }
.list-item-dot.cal-evenement.fam-5 { background: var(--fam5-bg); border: 2px solid var(--fam5-color); }
.list-item-dot.cal-evenement.fam-6 { background: var(--fam6-bg); border: 2px solid var(--fam6-color); }
.list-item-dot.cal-evenement.fam-7 { background: var(--fam7-bg); border: 2px solid var(--fam7-color); }
.min-w-0 { min-width: 0; }

/* ── Sélecteur famille dans formulaire ── */
.famille-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}
.famille-choice {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0.6rem 0.85rem;
    border-radius: 10px;
    border: 2px solid var(--fam-border, var(--sand));
    background: var(--fam-bg, var(--foam));
    color: var(--fam-color, var(--text));
    font-weight: 600;
    font-size: 0.9rem;
    cursor: pointer;
    transition: all 0.13s;
    user-select: none;
}
.famille-choice input[type="radio"] { display: none; }
.famille-choice:hover { transform: translateY(-1px); box-shadow: 0 3px 10px rgba(0,0,0,0.1); }
.famille-choice.selected,
.famille-choice:has(input:checked) {
    border-width: 3px;
    box-shadow: 0 0 0 3px rgba(0,0,0,0.07);
}

/* ── Formulaire ajout ── */
.form-card {
    background: var(--white);
    background: var(--mod-soft);            /* fond teinté module (fallback blanc) */
    border-radius: 12px;
    padding: 1.75rem;
    border: 1px solid var(--sand);
    border-color: var(--mod-line);
    border-top: 3px solid var(--mod-color); /* accent module */
    box-shadow: 0 2px 10px rgba(61,18,53,0.07);
}

/* Enfants checkboxes */
.enfant-check {
    background: var(--foam);
    border: 1.5px solid var(--sand);
    border-radius: 8px;
    padding: 0.4rem 0.85rem;
    cursor: pointer;
}
.enfant-check:has(.form-check-input:checked) {
    background: var(--select);
    border-color: var(--primary-light);
}
.enfant-check .form-check-label { cursor: pointer; color: var(--primary-mid); }

/* ── Galerie photos ── */
.gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 4px;
}
.gallery-item {
    position: relative;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    cursor: pointer;
    border-radius: 6px;
    background: var(--sand);
}
.gallery-thumb {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .25s, filter .25s;
}
.gallery-overlay {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    background: rgba(92,31,82,0);
    color: white; font-size: 1.4rem;
    opacity: 0;
    transition: background .2s, opacity .2s;
}
.gallery-item:hover .gallery-thumb  { transform: scale(1.06); filter: brightness(.85); }
.gallery-item:hover .gallery-overlay { background: rgba(92,31,82,0.4); opacity: 1; }

/* Bouton supprimer photo */
.gallery-del-form { position: absolute; top: 4px; right: 4px; }
.gallery-del-btn {
    background: rgba(0,0,0,0.55);
    border: none;
    color: white;
    width: 26px; height: 26px;
    border-radius: 50%;
    font-size: 0.75rem;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    opacity: 0;
    transition: opacity .15s;
}
.gallery-item:hover .gallery-del-btn { opacity: 1; }

/* Lightbox */
.gallery-lightbox {
    display: none;
    position: fixed; inset: 0; z-index: 9000;
    background: rgba(0,0,0,0.92);
    align-items: center; justify-content: center;
}
.gallery-lightbox.active { display: flex; }
.gallery-lb-inner {
    display: flex; flex-direction: column; align-items: center;
    max-width: 92vw; max-height: 92vh;
    padding: 0 3.5rem;
}
.gallery-lb-inner img {
    max-width: 100%; max-height: 78vh;
    border-radius: 8px;
    object-fit: contain;
    box-shadow: 0 8px 40px rgba(0,0,0,0.55);
}
.gallery-lb-caption { color: rgba(255,255,255,0.75); font-size: var(--fs-meta); margin-top: 0.8rem; text-align: center; }
.gallery-lb-counter { color: rgba(255,255,255,0.38); font-size: var(--fs-micro); margin-top: 3px; }
.gallery-lb-close, .gallery-lb-prev, .gallery-lb-next {
    position: fixed;
    background: rgba(255,255,255,0.12);
    border: none; color: white; border-radius: 50%;
    width: 46px; height: 46px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.15rem; cursor: pointer;
    transition: background .15s;
}
.gallery-lb-close:hover, .gallery-lb-prev:hover, .gallery-lb-next:hover { background: rgba(255,255,255,0.24); }
.gallery-lb-close { top: 1rem; right: 1rem; }
.gallery-lb-prev  { left:  .75rem; top: 50%; transform: translateY(-50%); }
.gallery-lb-next  { right: .75rem; top: 50%; transform: translateY(-50%); }

/* ── Admin ── */
.admin-tabs .nav-link { color: var(--muted); }
.admin-tabs .nav-link:hover { color: var(--primary); }
.admin-tabs .nav-link.active { color: var(--primary); border-bottom: 3px solid var(--primary); font-weight: 600; }

/* Onglets admin : ruban scrollable horizontalement sur mobile/tablette */
@media (max-width: 991.98px) {
    .admin-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;               /* Firefox */
        border-bottom: 1px solid var(--sand);
    }
    .admin-tabs::-webkit-scrollbar { display: none; } /* Chrome/Safari */
    .admin-tabs .nav-item { flex: 0 0 auto; }
    .admin-tabs .nav-link {
        white-space: nowrap;
        padding: .55rem .8rem;
        font-size: .85rem;
    }
    /* Le badge compteur reste collé au libellé */
    .admin-tabs .nav-link .badge { vertical-align: middle; }
}
.admin-field-label {
    font-size: 0.75rem; font-weight: 700;
    color: var(--muted); text-transform: uppercase;
    letter-spacing: 0.06em; margin-bottom: 0.2rem; display: block;
}
.stat-mini {
    background: white; border: 1px solid var(--sand); border-radius: 8px;
    padding: 0.4rem 0.9rem; font-size: var(--fs-meta); color: var(--muted); font-weight: 600;
}
.stat-mini span { font-size: 1.1rem; font-weight: 800; color: var(--primary); margin-right: 4px; }

/* Points de couleur familles */
.fam-dot {
    display: inline-block;
    width: 10px; height: 10px;
    border-radius: 50%;
    margin-right: 5px;
    flex-shrink: 0;
}
.fam-dot.fam-1 { background: var(--fam1-color); }
.fam-dot.fam-2 { background: var(--fam2-color); }
.fam-dot.fam-3 { background: var(--fam3-color); }
.fam-dot.fam-4 { background: var(--fam4-color); }
.fam-dot.fam-5 { background: var(--fam5-color); }
.fam-dot.fam-6 { background: var(--fam6-color); }
.fam-dot.fam-7 { background: var(--fam7-color); }

/* Badge enfants */
.badge-enfant {
    background: var(--select);
    color: var(--primary);
    font-size: 0.8rem;
    font-weight: 700;
    border-radius: 8px;
    padding: 3px 10px;
}

/* ── Upload form ── */
.upload-form {
    background: var(--foam);
    border: 1.5px dashed var(--sand);
    border-radius: 10px;
    padding: 1rem 1.25rem;
}

/* ── Navigation cards (menu accueil) — 2 par ligne ── */
.nav-cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.85rem;
    margin-top: 1.25rem;
}
.nav-card {
    display: flex;
    flex-direction: column;
    border-radius: 16px;
    padding: 1.25rem 1.1rem 1rem;
    text-decoration: none !important;
    color: inherit;
    transition: transform .18s, box-shadow .18s;
    position: relative;
    overflow: hidden;
    min-height: 148px;
}
.nav-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 28px rgba(0,0,0,0.18);
    color: inherit;
}
.nav-card::before {
    content: '';
    position: absolute;
    top: -24px; right: -24px;
    width: 90px; height: 90px;
    border-radius: 50%;
    background: rgba(255,255,255,0.07);
}
.card-primary {
    background: linear-gradient(135deg, var(--primary-mid) 0%, var(--primary) 100%);
    color: #fff !important;
    box-shadow: 0 4px 18px rgba(78,48,128,0.30);
    border: none;
}
.card-accent {
    background: linear-gradient(135deg, #5c1f52 0%, var(--accent) 100%);
    color: #fff !important;
}
.card-todo {
    background: linear-gradient(135deg, #0f766e 0%, #0369a1 100%);
    color: #fff !important;
    box-shadow: 0 4px 18px rgba(15,118,110,0.30);
    border: none;
}
.card-docs {
    background: linear-gradient(135deg, #0369a1 0%, #7850dc 100%);
    color: #fff !important;
    box-shadow: 0 4px 18px rgba(3,105,161,0.30);
    border: none;
}
.card-votes {
    background: linear-gradient(135deg, #7850dc 0%, #be123c 100%);
    color: #fff !important;
    box-shadow: 0 4px 18px rgba(120,80,220,0.30);
    border: none;
}
.card-cadeaux {
    background: linear-gradient(135deg, #be123c 0%, #f97316 100%);
    color: #fff !important;
    box-shadow: 0 4px 18px rgba(190,18,60,0.30);
    border: none;
}
/* ══════════════════ Chat familial ══════════════════ */
/* Wrapper watermark */
.chat-scroll-wrap {
    position: relative;
    flex: 1 1 auto;
    min-height: 0;
    background: var(--foam);
}
.chat-watermark {
    position: absolute; inset: 0;
    background-image: url('/images/logo.png');
    background-size: 42px;
    background-repeat: repeat;
    filter: brightness(0) opacity(0.04);
    pointer-events: none;
}

.chat-scroll {
    position: relative;
    flex: 1 1 auto; height: 100%; overflow-y: auto;
    background: transparent;
    -webkit-overflow-scrolling: touch;
}
.chat-row { display: flex; gap: 8px; align-items: flex-start; }
.chat-row.mine { justify-content: flex-end; }
.chat-avatar {
    width: 22px; height: 22px; border-radius: 50%; color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 0.52rem; font-weight: 800; flex-shrink: 0; margin-top: 4px;
}
.chat-col { max-width: 78%; display: flex; flex-direction: column; }
.chat-row.mine .chat-col { align-items: flex-end; }
.chat-name-inline {
    display: block; font-size: .68rem; font-weight: 700;
    margin-bottom: 2px;
}
.chat-bubble {
    position: relative; background: #fff; border: 1px solid var(--sand);
    border-radius: 14px; padding: 8px 12px 6px; font-size: 0.92rem;
    word-break: break-word; cursor: pointer; line-height: 1.35;
}
.chat-bubble.mine {
    background: color-mix(in srgb, var(--bubble-color, var(--mod-color)) 18%, #fff);
    border-color: color-mix(in srgb, var(--bubble-color, var(--mod-color)) 30%, #fff);
    color: #1e293b;
}
.chat-bubble.mine .chat-time {
    color: color-mix(in srgb, var(--bubble-color, var(--mod-color)) 80%, #000);
    opacity: .7;
}
.chat-text-body { display: inline; }
.chat-time { font-size: 0.6rem; color: var(--muted); margin-left: 10px; float: right; margin-top: 4px; }
.chat-img { max-width: min(220px, 60vw); border-radius: 10px; display: block; cursor: zoom-in; }
.chat-caption { margin-top: 5px; font-size: 0.88rem; }
.chat-reacts {
    display: flex; gap: 4px; flex-wrap: wrap;
    margin-top: -8px; padding-top: 0;
    position: relative; z-index: 1;
}
.chat-react-chip {
    font-size: 0.74rem; background: #fff; border: 1px solid var(--sand);
    border-radius: 12px; padding: 1px 7px; cursor: pointer;
    box-shadow: 0 1px 3px rgba(0,0,0,.12);
}
.chat-react-chip.mine {
    background: color-mix(in srgb, var(--bubble-color, var(--mod-color)) 15%, #fff);
    border-color: color-mix(in srgb, var(--bubble-color, var(--mod-color)) 40%, #fff);
    font-weight: 700;
}
.chat-react-picker { display: none; gap: 4px; margin-top: 5px; }
.chat-react-picker.show { display: flex; }
.chat-react-picker button {
    font-size: 1.15rem; background: #fff; border: 1px solid var(--sand);
    border-radius: 50%; width: 36px; height: 36px; line-height: 1; cursor: pointer;
    box-shadow: 0 2px 6px rgba(0,0,0,0.08);
}
.chat-react-picker button:active { transform: scale(0.9); }
.chat-react-picker button.picked {
    background: var(--mod-soft);
    border-color: var(--mod-color);
    box-shadow: 0 0 0 2px var(--mod-color);   /* anneau = déjà choisi (re-tap pour retirer) */
}

/* Barre de saisie */
.chat-input-bar {
    flex: none; display: flex; align-items: flex-end; gap: 8px;
    padding: 8px 10px; padding-bottom: calc(8px + env(safe-area-inset-bottom));
    background: #fff; border-top: 1px solid var(--sand);
}
.chat-textarea {
    width: 100%; border: 1px solid var(--sand); border-radius: 20px;
    padding: 10px 14px; resize: none; font-size: 16px; line-height: 1.3;
    max-height: 120px; font-family: var(--font-body);
}
.chat-textarea:focus { outline: none; border-color: var(--mod-color); }
.chat-icon-btn, .chat-send-btn {
    min-width: 44px; width: 44px; height: 44px; border-radius: 50%;
    border: none; display: flex; align-items: center; justify-content: center;
    font-size: 1.15rem; flex-shrink: 0; cursor: pointer;
}
.chat-icon-btn { background: var(--foam); color: var(--mod-color); }
.chat-send-btn { background: var(--mod-color); color: #fff; }
.chat-send-btn:disabled { opacity: 0.5; }
.chat-image-preview {
    position: absolute; bottom: calc(100% + 6px); left: 0;
    background: #fff; border: 1px solid var(--sand); border-radius: 10px; padding: 4px;
    box-shadow: 0 4px 14px rgba(0,0,0,0.12);
}
.chat-image-preview img { width: 60px; height: 60px; object-fit: cover; border-radius: 7px; display: block; }
.chat-image-remove {
    position: absolute; top: -8px; right: -8px; width: 22px; height: 22px;
    border-radius: 50%; border: none; background: var(--danger); color: #fff;
    font-size: 0.8rem; line-height: 1; cursor: pointer;
}

/* Lightbox */
.chat-lightbox {
    display: none; position: fixed; inset: 0; z-index: 2000;
    background: rgba(0,0,0,0.92); align-items: center; justify-content: center;
}
.chat-lightbox.show { display: flex; }
.chat-lightbox img { max-width: 96vw; max-height: 92vh; border-radius: 8px; }
.chat-lb-close {
    position: absolute; top: 14px; right: 14px; width: 44px; height: 44px;
    border-radius: 50%; border: none; background: rgba(255,255,255,0.15); color: #fff; font-size: 1.2rem;
}
/* Séparateur de date entre messages */
.chat-date-sep {
    display: flex; align-items: center; gap: 8px;
    margin: 10px 12px 6px; color: var(--muted);
    font-size: var(--fs-micro);
}
.chat-date-sep::before,
.chat-date-sep::after { content: ''; flex: 1; height: 1px; background: var(--sand); }
.chat-date-sep span { white-space: nowrap; }

/* Barre de citation (répondre à un message) */
.chat-reply-bar {
    flex: none; display: flex; align-items: center; gap: 8px;
    background: var(--foam); border-top: 2px solid var(--mod-color);
    padding: 6px 12px;
}
.chat-reply-preview { flex: 1; min-width: 0; }
.chat-reply-rname { display: block; font-size: .7rem; font-weight: 700; }
.chat-reply-rtext {
    display: block; font-size: .75rem; color: var(--muted);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.chat-reply-cancel {
    background: none; border: none; color: var(--muted);
    font-size: .85rem; padding: 2px 6px; flex-shrink: 0; cursor: pointer;
}

/* Citation dans la bulle */
.chat-quote {
    background: rgba(0,0,0,.07); border-left: 3px solid var(--mod-color);
    border-radius: 6px; padding: 4px 8px; margin-bottom: 6px; cursor: pointer;
}
.chat-bubble.mine .chat-quote {
    background: color-mix(in srgb, var(--bubble-color, var(--mod-color)) 8%, #fff);
    border-color: color-mix(in srgb, var(--bubble-color, var(--mod-color)) 45%, #fff);
}
.chat-quote-name { display: block; font-size: .68rem; font-weight: 700; }
.chat-quote-text {
    display: block; font-size: .78rem; color: var(--muted);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 240px;
}
.chat-bubble.mine .chat-quote-text { color: #475569; }

/* Bouton répondre — masqué visuellement, conservé dans le DOM pour les data-* du menu long-press */
.chat-reply-btn { display: none; }

/* Flash de surbrillance sur scroll-to */
@keyframes msg-flash {
    0%, 100% { box-shadow: none; }
    30%, 70% { box-shadow: 0 0 0 3px rgba(79,70,229,.45); }
}
.chat-highlight .chat-bubble { animation: msg-flash .9s ease; }

/* Supprime le menu natif iOS / sélection sur les bulles */
.chat-bubble {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
}

/* ── Chat — aperçu de lien ── */
.chat-link { color: var(--accent); text-underline-offset: 2px; word-break: break-all; }
.chat-link-preview {
    display: block; text-decoration: none; color: inherit;
    border: 1px solid var(--sand); border-radius: 12px;
    overflow: hidden; margin-top: 8px;
    background: var(--foam);
    max-width: 280px;
    transition: box-shadow .15s;
}
.chat-link-preview:hover { box-shadow: 0 2px 10px rgba(0,0,0,.1); }
.chat-link-thumb {
    width: 100%; max-height: 150px;
    object-fit: cover; display: block;
}
.chat-link-meta { padding: 8px 10px; }
.chat-link-domain {
    font-size: .66rem; color: var(--muted);
    text-transform: uppercase; letter-spacing: .05em; margin-bottom: 3px;
}
.chat-link-title {
    font-size: .82rem; font-weight: 600; color: var(--text);
    line-height: 1.3; margin-bottom: 3px;
    display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}
.chat-link-desc {
    font-size: .74rem; color: var(--muted); line-height: 1.3;
    display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}

/* ── Menu contextuel long-press ── */
.chat-ctx-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.45);
    backdrop-filter: blur(2px); -webkit-backdrop-filter: blur(2px);
    z-index: 1050;
    opacity: 0; pointer-events: none;
    transition: opacity .18s;
}
.chat-ctx-overlay.show { opacity: 1; pointer-events: auto; }
.chat-ctx-menu {
    position: fixed;
    z-index: 1051;
    background: #fff;
    border-radius: 18px;
    box-shadow: 0 8px 36px rgba(0,0,0,.28);
    padding: 10px 8px 8px;
    min-width: 220px;
    max-width: calc(100vw - 32px);
    opacity: 0; transform: scale(.88);
    pointer-events: none;
    transition: opacity .18s, transform .18s;
}
.chat-ctx-menu.show { opacity: 1; transform: scale(1); pointer-events: auto; }
.chat-ctx-emojis {
    display: flex; gap: 2px; justify-content: space-around;
    padding: 4px 4px 10px;
    border-bottom: 1px solid var(--sand);
    margin-bottom: 6px;
}
.ctx-emoji-btn {
    font-size: 1.65rem;
    background: none; border: 2px solid transparent;
    border-radius: 50%; width: 44px; height: 44px;
    cursor: pointer; display: flex; align-items: center; justify-content: center;
    transition: transform .1s;
}
.ctx-emoji-btn.picked { background: var(--foam); border-color: var(--sand); }
.ctx-emoji-btn:active { transform: scale(.82); }
.ctx-action-btn {
    display: flex; align-items: center; gap: 10px;
    width: 100%; padding: 9px 10px;
    background: none; border: none; border-radius: 10px;
    color: var(--text); font-size: .9rem;
    font-family: var(--font-body); cursor: pointer; text-align: left;
}
.ctx-action-btn:active { background: var(--foam); }
.ctx-action-btn i { font-size: 1rem; color: var(--muted); width: 20px; text-align: center; }

/* Indicateur "est en train d'écrire" */
.chat-typing {
    flex: none; font-size: var(--fs-meta); color: var(--muted);
    font-style: italic; background: var(--foam);
    border-top: 1px solid var(--sand);
    animation: typing-fade 0.3s ease;
}
@keyframes typing-fade { from { opacity: 0; } to { opacity: 1; } }

/* Badge "nouveaux messages" */
.chat-newbadge {
    position: fixed; bottom: 80px; left: 50%; transform: translateX(-50%);
    background: var(--mod-color); color: #fff;
    padding: 6px 14px; border-radius: 20px; font-size: .82rem; font-weight: 600;
    cursor: pointer; box-shadow: 0 2px 8px rgba(0,0,0,.25);
    z-index: 100; white-space: nowrap;
    animation: badge-pop .2s ease;
}
@keyframes badge-pop { from { transform: translateX(-50%) scale(.8); opacity:0; } to { transform: translateX(-50%) scale(1); opacity:1; } }

/* Accusés de lecture — coches style WhatsApp */
.chat-tick {
    font-size: .78rem; margin-left: 0; vertical-align: middle;
    letter-spacing: -3px;
    color: color-mix(in srgb, var(--bubble-color, var(--mod-color)) 40%, #aaa);
}
.chat-tick.read {
    color: var(--bubble-color, var(--mod-color));
}

/* Desktop : fil centré et lisible */
@media (min-width: 768px) {
    #chat-messages, #chat-loadmore { max-width: 760px; margin-left: auto; margin-right: auto; }
    .chat-input-bar { max-width: 780px; margin: 0 auto; width: 100%; }
    .chat-typing { max-width: 780px; margin: 0 auto; width: 100%; }
}

/* Bandeau accueil */
.chat-banner {
    display: block; text-decoration: none !important; border-radius: 16px;
    background: linear-gradient(135deg, #4f46e5 0%, #7c3aed 100%);
    color: #fff !important; padding: 0.85rem 1.1rem; margin-bottom: 1rem;
    box-shadow: 0 4px 18px rgba(79,70,229,0.28); position: relative; overflow: hidden;
}
.chat-banner-head { display: flex; align-items: center; gap: 8px; font-weight: 800;
    font-family: var(--font-display); font-size: 0.95rem; margin-bottom: 0.4rem; }
.chat-banner-line { font-size: 0.8rem; opacity: 0.95; line-height: 1.5;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.chat-banner-line b { font-weight: 700; }
.chat-banner-empty { font-size: 0.85rem; opacity: 0.95; }
.chat-banner-arrow { position: absolute; right: 14px; top: 50%; transform: translateY(-50%);
    font-size: 1.1rem; opacity: 0.85; }

/* Badge non-lus sur l'icône header */
.chat-nav-wrap { position: relative; display: inline-flex; }
.chat-nav-badge {
    position: absolute; top: -5px; right: -5px; min-width: 17px; height: 17px;
    padding: 0 4px; border-radius: 9px; background: var(--danger); color: #fff;
    font-size: 0.62rem; font-weight: 800; line-height: 17px; text-align: center;
    box-shadow: 0 0 0 2px var(--primary-mid);
}
.chat-nav-badge.d-none { display: none; }

/* ── Boutons ajout rapide (accueil) ── */
.quick-add-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.6rem;
}
.quick-add-btn {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: .75rem 1rem;
    border-radius: 12px;
    text-decoration: none !important;
    color: #fff !important;
    font-family: var(--font-display);
    font-size: .82rem;
    font-weight: 700;
    transition: transform .15s, box-shadow .15s;
    overflow: hidden;
    position: relative;
}
.quick-add-btn::before {
    content: '';
    position: absolute;
    top: -14px; right: -14px;
    width: 50px; height: 50px;
    border-radius: 50%;
    background: rgba(255,255,255,0.08);
}
.quick-add-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(0,0,0,0.18);
}
.quick-add-btn i { font-size: 1.25rem; flex-shrink: 0; }
.quick-add-garde { background: linear-gradient(135deg, var(--primary-mid) 0%, var(--primary) 100%); }
.quick-add-event { background: linear-gradient(135deg, var(--accent) 0%, #0369a1 100%); }

.nav-card-icon {
    font-size: 1.7rem;
    opacity: 0.9;
    margin-bottom: 0.6rem;
    line-height: 1;
}
.nav-card-title {
    font-family: var(--font-display);
    font-size: 1.05rem;
    font-weight: 800;
    margin-bottom: 0.25rem;
    letter-spacing: -0.01em;
}
.nav-card-desc {
    font-size: 0.75rem;
    opacity: 0.82;
    margin-bottom: auto;
    padding-bottom: 0.75rem;
    line-height: 1.35;
}
.nav-card-stat {
    font-size: var(--fs-micro);
    font-weight: 700;
    background: rgba(0,0,0,0.18);
    border-radius: 6px;
    padding: 3px 8px;
    display: inline-block;
    letter-spacing: 0.02em;
    margin-top: 0.6rem;
}
/* Grille familles (section accueil) */
.home-fam-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
    gap: 10px;
    margin-top: 0.75rem;
}
.home-fam-chip {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0.55rem 0.9rem;
    border-radius: 10px;
    font-size: 0.87rem;
    font-weight: 600;
    border: 2px solid var(--fam-border, var(--sand));
    background: var(--fam-bg, var(--foam));
    color: var(--fam-color, var(--text));
    text-decoration: none !important;
    transition: transform .13s, box-shadow .13s;
}
.home-fam-chip:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    color: var(--fam-color, var(--text));
}
/* ── Identité de module — teintes dérivées de --mod-color ──
   --mod-color est défini par page (inline dans le header).
   Les teintes douces se recalculent automatiquement par module. */
:root {
    --mod-color: var(--primary);
    --mod-soft:  color-mix(in srgb, var(--mod-color)  6%, #fff);   /* fond très clair */
    --mod-wash:  color-mix(in srgb, var(--mod-color) 11%, #fff);   /* fond léger      */
    --mod-line:  color-mix(in srgb, var(--mod-color) 24%, #fff);   /* bordure douce   */
}
/* Section title home — prend la couleur du module */
.home-section-title {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--mod-color);
    margin-bottom: 0.6rem;
}
/* Galerie all-photos */
.galerie-month-title {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
    color: var(--primary-mid);
    padding: 0.4rem 0;
    border-bottom: 2px solid var(--sand);
    margin-bottom: 0.85rem;
}
.galerie-photo-badge {
    position: absolute;
    bottom: 4px; left: 4px;
    font-size: 0.62rem;
    font-weight: 700;
    border-radius: 5px;
    padding: 1px 5px;
    color: #fff;
    line-height: 1.4;
    text-shadow: none;
    opacity: 0.92;
}
.galerie-photo-badge.fam-1 { background: var(--fam1-color); }
.galerie-photo-badge.fam-2 { background: var(--fam2-color); }
.galerie-photo-badge.fam-3 { background: var(--fam3-color); }
.galerie-photo-badge.fam-4 { background: var(--fam4-color); }
.galerie-photo-badge.fam-5 { background: var(--fam5-color); }
.galerie-photo-badge.fam-6 { background: var(--fam6-color); }
.galerie-photo-badge.fam-7 { background: var(--fam7-color); }

/* ── Garde couleur unifiée ── */
.cal-garde { background: var(--garde-bg); color: #fff; border-left: 4px solid var(--garde-border); }
.cal-garde.cal-garde-pending {
    background: #d1fae5 !important;
    color: #065f46 !important;
    border: 2px dashed #047857 !important;
    border-left: 4px dashed #047857 !important;
    opacity: 1;
}
.cal-legend.cal-garde { background: var(--garde-bg); border: 2px solid var(--garde-border); }
.list-item-dot.cal-garde { background: var(--garde-color); }
.list-item.garde-item { border-left: 4px solid var(--garde-color); }
.detail-card.garde-item { border-top: 4px solid var(--garde-color); }
.detail-card.garde-item .detail-icon { color: var(--garde-color); }

/* ── Événement couleur unifiée ── */
.list-item.event-item { border-left: 4px solid var(--event-color); }
.detail-card.event-item { border-top: 4px solid var(--event-color); }
.detail-card.event-item .detail-icon { color: var(--event-color); }

/* ── Jours fériés et vacances ── */
.cal-cell.cal-ferie-day   { background: #fecaca !important; }
.cal-cell.cal-vacance-day { background: #fffbeb !important; }
.cal-ferie   { font-size: 0.58rem; font-weight: 700; color: #b91c1c; display: block; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; margin-bottom: 1px; }
.cal-vacance  { font-size: 0.58rem; font-weight: 600; color: #92400e; display: block; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; margin-bottom: 1px; }
.cal-birthday { font-size: 0.58rem; font-weight: 700; color: #be185d; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }

/* ── PIN numpad ── */
.pin-display {
    display: flex; gap: 14px; justify-content: center; margin: 1rem 0;
}
.pin-dot {
    width: 15px; height: 15px; border-radius: 50%;
    background: #e2e8f0; border: 2px solid #cbd5e1;
    transition: background .15s, border-color .15s;
}
.pin-dot.filled { background: var(--primary); border-color: var(--primary); }
.pin-pad {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 0.75rem;
}
.pin-btn {
    padding: 0.8rem 0.5rem; border: 1px solid var(--sand); border-radius: 10px;
    background: white; font-size: 1.2rem; font-weight: 700; cursor: pointer;
    transition: background .12s, transform .1s; color: var(--text);
    font-family: var(--font-body); line-height: 1;
}
.pin-btn:hover  { background: var(--foam); }
.pin-btn:active { transform: scale(0.93); background: var(--sand); }
.pin-btn.pin-clear  { color: var(--muted); font-size: 1rem; font-weight: 500; }
.pin-btn.pin-submit { background: var(--foam); color: var(--muted); border-color: var(--sand); font-size: 0.85rem; }
.pin-btn.pin-submit-ready { background: var(--primary); color: white !important; border-color: var(--primary); }
.pin-text-input { font-size: 1.5rem; letter-spacing: .5em; text-align: center; }

/* ── Anti-zoom iOS : 16px minimum sur les champs de saisie (mobile) ──────────
   Sous 16px, Safari iOS zoome automatiquement au focus et décale l'écran. */
@media (max-width: 767.98px) {
    input[type="text"], input[type="email"], input[type="password"],
    input[type="search"], input[type="tel"], input[type="number"],
    input[type="url"], input[type="date"], input[type="time"],
    textarea, select, .form-control {
        font-size: 16px;
    }
    .pin-text-input { font-size: 1.5rem; } /* garde le clavier PIN bien lisible */
}

/* ── Météo ── */
.weather-widget {
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 4px 18px rgba(61,18,53,0.12);
    border: none;
}
.weather-widget-header {
    background: linear-gradient(135deg, var(--primary-mid) 0%, var(--primary) 100%);
    color: #fff;
    padding: .55rem 1.1rem;
    display: flex;
    align-items: center;
    gap: .5rem;
    font-family: var(--font-display);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
}
.weather-two-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: #fff;
}
.weather-col {
    padding: .9rem 1.1rem;
}
.weather-col + .weather-col {
    border-left: 1px solid var(--sand);
}
.weather-city {
    font-family: var(--font-display);
    font-size: 0.68rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--primary);
    margin-bottom: .55rem;
}
.weather-current { display: flex; align-items: center; gap: 10px; }
.weather-icon    { font-size: 2.2rem; line-height: 1; flex-shrink: 0; }
.weather-temp    {
    font-family: var(--font-display);
    font-size: 1.8rem;
    font-weight: 800;
    color: var(--primary-mid);
    line-height: 1;
}
.weather-desc    { font-size: var(--fs-badge); color: var(--muted); margin-top: 3px; font-weight: 600; }
.weather-forecast {
    display: flex;
    gap: 4px;
    margin-top: .7rem;
    padding-top: .6rem;
    border-top: 1px solid var(--sand);
}
.weather-day {
    flex: 1;
    text-align: center;
    background: var(--foam);
    border-radius: 8px;
    padding: 5px 3px;
    border: 1px solid var(--sand);
}
.weather-day-name {
    font-family: var(--font-display);
    font-size: 0.58rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--primary);
}
.weather-day-icon { font-size: 1rem; display: block; margin: 3px 0; }
.weather-day-max  {
    font-family: var(--font-display);
    font-size: var(--fs-badge);
    font-weight: 800;
    color: var(--primary-mid);
}
.weather-day-min  { font-size: var(--fs-micro); color: var(--muted); }

/* ── Gardien chip ── */
.gardien-chip {
    display: inline-flex; align-items: center; gap: 6px;
    padding: .45rem .85rem; border-radius: 10px; border: 2px solid;
    cursor: pointer; transition: border-color .12s, border-width .12s, box-shadow .12s;
    user-select: none;
}
.gardien-chip input[type="radio"] { display: none; }
.gardien-chip:hover    { box-shadow: 0 2px 8px rgba(0,0,0,.12); }
.gardien-chip.active   { box-shadow: 0 0 0 3px rgba(0,0,0,.08); }

/* ── Tuile calendrier cliquable ── */
.cal-cell:not(.cal-empty) { cursor: pointer; transition: box-shadow .12s; }
.cal-cell:not(.cal-empty):hover {
    box-shadow: inset 0 0 0 1px rgba(92,31,82,0.4);
}
.cal-cell.cal-day-sel {
    background: #f0d9ed !important;
    box-shadow: inset 0 0 0 2px var(--primary) !important;
}

/* ── Panneau jour ── */
.day-panel {
    background: var(--white);
    border-radius: 12px;
    border: 1px solid var(--sand);
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,0.07);
}
.day-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .75rem 1.25rem;
    background: linear-gradient(135deg, var(--primary-mid) 0%, var(--primary) 100%);
    color: white;
    font-weight: 700;
    font-size: .95rem;
}
.day-panel-header .btn-close-detail { color: rgba(255,255,255,.75); }
.day-panel-header .btn-close-detail:hover { background: rgba(255,255,255,.15); color: white; }
.day-panel-body { padding: 1rem 1.25rem; }
.day-ev-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: .5rem .75rem;
    border-radius: 8px;
    border: 1px solid var(--sand);
    background: var(--white);
    color: var(--text);
    cursor: pointer;
    transition: background .14s, box-shadow .14s;
}
.day-ev-item:hover {
    background: var(--foam);
    box-shadow: 0 2px 8px rgba(92,31,82,.10);
    color: var(--text);
}
.day-ev-item.garde-item { border-left: 4px solid var(--garde-bg); }
.day-ev-item.garde-item:hover { background: #ecfdf5; }
.day-ev-item.event-item { border-left: 4px solid var(--event-bg); }
.day-ev-item.event-item:hover { background: #fff1eb; }
.day-ev-item.birthday-item { border-left: 4px solid #f9a8d4; background: #fdf2f8; }

/* ── Bouton + Événement dans le panneau jour ── */
.btn-event {
    color: var(--event-color);
    border: 1px solid var(--event-color);
    border-radius: 6px;
    padding: .25rem .75rem;
    text-decoration: none;
    background: transparent;
    transition: background .15s, color .15s, border-color .15s;
    display: inline-flex; align-items: center;
}
.btn-event:hover, .btn-event:focus {
    background: var(--event-color);
    color: #fff;
    border-color: var(--event-color);
}

/* ── Chips groupe gardien ── */
.groupe-chip {
    display: inline-flex; align-items: center; gap: 6px;
    padding: .45rem .9rem; border-radius: 10px;
    border: 2px solid #6ee7b7;
    background: #ecfdf5; color: #065f46;
    cursor: pointer; font-weight: 600; font-size: .88rem;
    transition: border-color .12s, border-width .12s, box-shadow .12s;
    user-select: none;
}
.groupe-chip input[type="radio"] { display: none; }
.groupe-chip:hover { box-shadow: 0 2px 8px rgba(0,0,0,.1); }
.groupe-chip.active,
.groupe-chip:has(input:checked) {
    border-width: 3px;
    border-color: #065f46;
    background: #d1fae5;
    box-shadow: 0 0 0 3px rgba(4,120,87,.2);
}

/* ── Récurrence ajouter ── */
.recur-days-wrap { display: flex; flex-wrap: wrap; gap: 6px; }

/* ── Todo Lists ── */
.todo-create-form {
    display: flex; align-items: center; gap: 8px;
    background: var(--white); border: 1.5px solid var(--sand);
    border-radius: 10px; padding: .55rem .85rem;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
}
.todo-list-card {
    display: flex; align-items: stretch; gap: 0;
    background: var(--white); border: 1.5px solid var(--sand);
    border-radius: 12px; overflow: hidden;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
    transition: box-shadow .15s, transform .15s;
}
.todo-list-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.10); transform: translateY(-1px); }
.todo-list-done { opacity: .7; }
.todo-list-link {
    flex: 1; padding: .85rem 1rem; min-width: 0; color: var(--text);
}
.todo-list-link:hover { color: var(--text); }
.todo-list-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 5px; flex-wrap: wrap; }
.todo-list-titre { font-weight: 700; font-size: .97rem; color: var(--primary-mid); }
.todo-progress-wrap {
    width: 100%; height: 5px; background: var(--sand);
    border-radius: 3px; overflow: hidden; margin-top: 6px;
}
.todo-progress-bar { height: 100%; background: var(--accent); border-radius: 3px; transition: width .4s; }
.todo-creator-badge {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 2px 8px; border-radius: 20px; font-size: var(--fs-badge);
    font-weight: 700; border: 1.5px solid;
}
.todo-delete-form { display: flex; align-items: center; padding: .5rem .6rem; }
.todo-del-btn { opacity: .5; transition: opacity .15s; }
.todo-del-btn:hover { opacity: 1; }

/* Détail todo */
.todo-detail-header {
    background: var(--white); border: 1.5px solid var(--sand);
    border-radius: 12px; padding: 1rem 1.25rem;
}
.todo-add-form {
    display: flex; align-items: center; gap: 8px;
    background: var(--white); border: 1.5px solid var(--sand);
    border-radius: 10px; padding: .55rem .85rem;
    position: sticky; bottom: 12px;
    box-shadow: 0 2px 12px rgba(0,0,0,.10);
}
.todo-item {
    display: flex; align-items: center; gap: 10px;
    padding: .65rem .75rem; border-radius: 10px;
    background: var(--white); border: 1.5px solid var(--sand);
    margin-bottom: 6px; transition: opacity .2s, background .2s;
}
.todo-item-checked { opacity: .55; background: var(--foam); }
.todo-item-checked .todo-item-text { text-decoration: line-through; color: var(--muted); }
.todo-checkbox {
    width: 26px; height: 26px; border-radius: 50%; flex-shrink: 0;
    border: 2px solid var(--item-border, var(--sand));
    background: transparent; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    font-size: .85rem; color: var(--item-color, var(--accent));
    transition: background .15s, border-color .15s;
}
.todo-checkbox:hover { background: var(--foam); }
.todo-checkbox-checked {
    background: var(--item-color, var(--accent)) !important;
    border-color: var(--item-color, var(--accent)) !important;
    color: #fff !important;
}
.todo-item-content { min-width: 0; }
.todo-item-text { font-size: .9rem; display: block; }
.todo-item-meta { display: flex; align-items: center; gap: 4px; margin-top: 2px; }
.todo-del-item-btn {
    background: none; border: none; padding: 4px 6px;
    color: var(--muted); opacity: .4; border-radius: 6px;
    transition: opacity .15s, color .15s; flex-shrink: 0;
    font-size: .8rem; cursor: pointer;
}
.todo-del-item-btn:hover { opacity: 1; color: #ef4444; }

/* ── Chip utilisateur connecté (header) ── */
.nav-user-chip {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(255,255,255,.92);
    border-radius: 20px;
    padding: 3px 10px 3px 6px;
    color: var(--primary-mid);
    font-weight: 700;
    transition: background .15s, opacity .15s;
    flex-shrink: 0;
}
.nav-user-chip:hover { background: #fff; color: var(--primary-mid); opacity: .9; }
.nav-user-name { font-size: .75rem; font-weight: 700; white-space: nowrap; color: var(--primary-mid); }

/* ── PIN : saisie native sur tactile (téléphone + tablette) ── */
.pin-native-wrap { display: none; }
.pin-native-input {
    width: 100%; text-align: center; letter-spacing: .5em;
    font-size: 1.6rem; font-weight: 700; padding: .6rem 1rem;
    border: 2px solid var(--sand); border-radius: 12px;
    background: var(--foam); color: var(--text);
    outline: none; margin-top: .5rem;
    -webkit-appearance: none;
}
.pin-native-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(15,118,110,.15); }
/* Appareils tactiles (téléphone ET tablette) : pavé + ronds masqués, clavier natif affiché */
@media (hover: none) and (pointer: coarse) {
    .pin-pad     { display: none !important; }
    .pin-display { display: none !important; }
    .pin-native-wrap { display: block; }
}

/* ── Todo : compteurs de caractères ── */
.todo-char-count {
    font-size: var(--fs-micro); color: var(--muted); white-space: nowrap;
    flex-shrink: 0; user-select: none;
}
.todo-char-count-inside {
    position: absolute; right: 6px; bottom: 4px;
    pointer-events: none;
}
.todo-char-count.todo-char-warn { color: #dc2626; font-weight: 700; }

/* ── Todo : icône picker ── */
.todo-icon-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(38px, 1fr));
    gap: 4px;
    background: var(--white); border: 1.5px solid var(--sand);
    border-radius: 10px; max-height: 200px; overflow-y: auto;
}
.todo-icon-btn {
    width: 38px; height: 38px; border-radius: 8px;
    border: 1.5px solid transparent; background: transparent;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem; cursor: pointer; color: var(--text);
    transition: background .12s, border-color .12s;
}
.todo-icon-btn:hover { background: var(--foam); border-color: var(--sand); }
.todo-icon-btn.active { background: #d1fae5; border-color: var(--accent); color: var(--accent); }

/* ── Todo : légende ── */
.todo-legend {
    display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
    padding: .4rem .6rem; background: var(--foam);
    border: 1px solid var(--sand); border-radius: 8px;
    font-size: .75rem;
}
.todo-legend-item {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 2px 8px; border-radius: 20px; font-weight: 600;
    border: 1.5px solid;
}

/* ── Responsive ── */
@media (max-width: 576px) {
    .page-title { font-size: 1.2rem; }
    .cal-cell { height: 64px; padding: 0.18rem; overflow: hidden; }
    .cal-day-num { font-size: 0.7rem; }
    .cal-ev { font-size: 0.62rem; padding: 1px 3px; }
    .gallery-grid { grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); }
    .gallery-lb-inner { padding: 0 0.25rem; }
    .gallery-lb-prev { left: 0.25rem; }
    .gallery-lb-next { right: 0.25rem; }
    .family-grid { grid-template-columns: 1fr 1fr; }
    .detail-header { padding: 0.85rem 1rem; }
    .detail-body { padding: 0.85rem 1rem; }
    .form-card { padding: 1.25rem; }
    .weather-two-cols { grid-template-columns: 1fr; }
    .weather-col + .weather-col { border-left: none; border-top: 1px solid var(--sand); }
    /* Header mobile */
    .site-title { font-size: 0.88rem; }
    .site-page-title { font-size: .95rem; }
    .quick-add-btn { padding: .6rem .75rem; font-size: .76rem; }
}
