/* ==========================================================================
   calendrier.css — calendar : DM Sans/DM Serif, orange #C4622D, vert #4A7C6F
   Scopé sous .cal-wrap
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:wght@300;400;500;600&display=swap');

/* Reset local */
.cal-wrap, .cal-wrap *, .cal-wrap *::before, .cal-wrap *::after { box-sizing: border-box; }

/* Variables */
.cal-wrap {
    --c-bg:      #F7F5F0;
    --c-surface: #FFFFFF;
    --c-border-c:#E2DDD6;
    --c-text:    #1A1814;
    --c-muted:   #8C8880;
    --c-accent:  #C4622D;
    --c-accent2: #4A7C6F;
    --c-ev-bg:   #EAF3F1;
    --c-ev-bd:   #4A7C6F;
    --c-wknd:    #FAF0EB;
    --c-shadow:  0 2px 12px rgba(0,0,0,.07);
    --c-radius:  10px;
    --c-serif:   'DM Serif Display', serif;
    --c-gutter:  3rem;

    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 16px;
    color: var(--c-text);
    line-height: 1.4;
    width: 100%;
    padding: .75rem 0 1.5rem;
}

/* Surface commune */
.cal-wrap .cal-card {
    background: var(--c-surface);
    border: 1.5px solid var(--c-border-c);
    border-radius: var(--c-radius);
    overflow: hidden;
    box-shadow: var(--c-shadow);
}

/* ---- En-tête ---- */
.cal-wrap .cal-header {
    display: flex; align-items: flex-start; justify-content: space-between;
    flex-wrap: wrap; gap: .75rem; margin-bottom: 1.25rem;
}
.cal-wrap .cal-header h2 {
    font-family: var(--c-serif);
    font-size: 1.75rem; letter-spacing: -.02em; line-height: 1.15; margin: 0;
}
.cal-wrap .cal-header h2 span { color: var(--c-accent); font-style: italic; }

/* ---- Contrôles : types à gauche, nav à droite ---- */
.cal-wrap .cal-controls {
    display: flex; flex-wrap: wrap; gap: .4rem;
    align-items: center; justify-content: space-between; width: 100%;
}
.cal-wrap .cal-types        { display: flex; gap: .35rem; flex-wrap: wrap; align-items: center; }
.cal-wrap .cal-controls-sep { display: none; }

/* Classe unique pour tous les boutons pill */
.cal-wrap .cal-btn {
    display: inline-flex; align-items: center; justify-content: center;
    padding: .28rem .75rem; border-radius: 20px;
    border: 1.5px solid var(--c-border-c);
    font-size: .8rem; font-weight: 500; color: var(--c-muted);
    transition: all .15s; white-space: nowrap;
}
.cal-wrap .cal-btn:hover              { background: var(--c-text); border-color: var(--c-text); color: #fff; }
.cal-wrap .cal-btn.active             { border-color: var(--c-accent); color: var(--c-accent); font-weight: 600; }
.cal-wrap .cal-btn.active:hover       { background: var(--c-accent); border-color: var(--c-accent); color: #fff; }
.cal-wrap .cal-btn.today-btn          { border-color: var(--c-accent); color: var(--c-accent); font-weight: 600; }
.cal-wrap .cal-btn.today-btn:hover    { background: var(--c-accent); border-color: var(--c-accent); color: #fff; }

/* nav */
.cal-wrap .cal-nav { display: flex; align-items: center; gap: .35rem; }
.cal-wrap .cal-nav .cal-btn:not(.today-btn) { padding: 0 .5rem; min-width: 2rem; height: 2rem; font-size: .95rem; font-weight: 600; }
.cal-wrap .cal-nav .cal-btn:hover { background: var(--c-accent); border-color: var(--c-accent); color: #fff; }
.cal-wrap .cal-nav .cal-period { font-size: .8rem; font-weight: 600; min-width: 155px; text-align: center; }

/* ---- Numéro de jour + crayon : taille adaptative ---- */
.cal-wrap .cal-day-num,
.cal-wrap .cal-mini-day,
.cal-wrap .cal-write-btn {
    width: 1.6rem; height: 1.6rem; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: .77rem; font-weight: 600; cursor: pointer; flex-shrink: 0;
    color: var(--c-muted);
}
.cal-wrap .cal-mini-day {
    display: flex; margin: 0 auto;
    width: min(1.6rem, 100%); aspect-ratio: 1; height: auto; max-width: 1.6rem;
}
/* Hover identique partout : fond accent2, texte blanc */
.cal-wrap .cal-day-num-lnk { text-decoration: none; color: inherit; display: inline-block; }
.cal-wrap .cal-day-num-lnk:hover .cal-day-num,
.cal-wrap .cal-write-btn:hover,
.cal-wrap .cal-mini-cell:hover .cal-mini-day { background: var(--c-accent2); color: #fff; }

/* Crayon dans bandeau foncé — haut à droite */
.cal-wrap .cal-write-head {
    position: absolute; top: .3rem; right: .3rem;
    color: rgba(255,255,255,.6);
}
.cal-wrap .cal-write-head:hover { background: rgba(255,255,255,.25); color: #fff; }

/* Aujourd'hui : cercle orange */
.cal-wrap .cal-day.cal-today .cal-day-num,
.cal-wrap .cal-mini-day.is-today {
    border: 2px solid var(--c-accent); color: var(--c-accent); font-weight: 700;
}
/* Entrée : fond orange */
.cal-wrap .cal-mini-day.has-ev { background: var(--c-accent); color: #fff; }
/* Aujourd'hui + entrée */
.cal-wrap .cal-mini-day.is-today.has-ev { background: var(--c-accent); color: #fff; border: 2px solid var(--c-accent2); }

/* Cellule vue annuelle */
.cal-wrap .cal-mini-cell {
    cursor: pointer; display: flex; align-items: center; justify-content: center;
    padding: .1rem 0; min-width: 0;
}
/* Weekend : fond coloré, texte accent2. Le hover ci-dessus s'applique aussi grâce à !important non nécessaire
   car la règle hover a une spécificité égale et arrive après */
.cal-wrap .cal-mini-cell.cal-mini-weekend { background: var(--c-wknd); }
.cal-wrap .cal-mini-cell.cal-mini-weekend .cal-mini-day { color: var(--c-accent2); }
.cal-wrap .cal-mini-cell.cal-mini-weekend .cal-mini-day.has-ev { color: #fff; }
.cal-wrap .cal-mini-cell.cal-mini-weekend:hover .cal-mini-day { background: var(--c-accent2); color: #fff; }
/* Vue mensuelle : même couleur accent2 pour les numéros de weekend */
.cal-wrap .cal-day.cal-weekend .cal-day-num,
.cal-wrap .cal-day.cal-weekend .cal-day-num-lnk { color: var(--c-accent2); }

/* En-tête cellule mensuelle */
.cal-wrap .cal-day-top {
    display: flex; align-items: center; justify-content: space-between; margin-bottom: .15rem;
}

/* ---- Vue mensuelle : une seule grille, head et body en display:contents ---- */
.cal-wrap .cal-grid {
    display: grid; grid-template-columns: repeat(7, 1fr);
}
.cal-wrap .cal-grid-head,
.cal-wrap .cal-grid-body { display: contents; }
.cal-wrap .cal-grid-head > div {
    background: var(--c-text); color: #fff; text-align: center;
    font-size: .75rem; font-weight: 600; letter-spacing: .06em; text-transform: uppercase;
    padding: .55rem 0; min-width: 0; overflow: hidden;
}
.cal-wrap .cal-day {
    border-right: 1px solid var(--c-border-c); border-bottom: 1px solid var(--c-border-c);
    padding: .38rem .42rem; min-height: 76px; min-width: 0; overflow: hidden;
}
.cal-wrap .cal-day:nth-child(7n)  { border-right: none; }
.cal-wrap .cal-day.cal-empty      { background: var(--c-bg); opacity: .55; }
.cal-wrap .cal-day.cal-weekend    { background: var(--c-wknd); }
.cal-wrap .cal-day.cal-has-events { background: var(--c-ev-bg); }

/* ---- Vue annuelle ---- */
.cal-wrap .cal-annual { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1rem; }
.cal-wrap .cal-month-mini-head {
    background: var(--c-text); color: #fff; text-align: center;
    padding: .42rem; font-size: .93rem; font-weight: 600;
}
.cal-wrap .cal-month-mini-grid {
    display: grid; grid-template-columns: repeat(7, 1fr); padding: .25rem; gap: 1px;
}
.cal-wrap .cal-month-mini-grid .col-head {
    text-align: center; font-size: .59rem; font-weight: 600; min-width: 0; overflow: hidden;
    color: var(--c-muted); text-transform: uppercase; letter-spacing: .04em; padding: .1rem 0;
}

/* ---- Événements inline ---- */
.cal-wrap .cal-ev-list { margin-top: .28rem; display: flex; flex-direction: column; gap: .2rem; }
.cal-wrap .cal-ev-item {
    border-left: 3px solid var(--c-ev-bd); background: #fff;
    border-radius: 4px; padding: .16rem .36rem; font-size: .69rem; line-height: 1.3; overflow: hidden;
}
.cal-wrap .cal-ev-item .ev-titre         { font-weight: 600; }
.cal-wrap .cal-ev-item .ev-titre a       { color: inherit; }
.cal-wrap .cal-ev-item .ev-titre a:hover { color: var(--c-accent); text-decoration: underline; }
.cal-wrap .cal-ev-item .ev-heure,
.cal-wrap .cal-ev-item .ev-extrait       { color: var(--c-muted); font-size: .65rem; }
.cal-wrap .cal-ev-item .ev-extrait {
    margin-top: .1rem; display: -webkit-box;
    -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* ==========================================================================
   TIMELINE
   ========================================================================== */
.cal-wrap .cal-week { width: 100%; overflow: hidden; border-radius: var(--c-radius); }

/* Un seul conteneur scrollable */
.cal-wrap .cal-tl-scroll {
    overflow-y: scroll; overflow-x: hidden; height: 580px;
    scrollbar-width: thin; scrollbar-color: #ccc transparent;
}
.cal-wrap .cal-tl-scroll::-webkit-scrollbar       { width: 6px; }
.cal-wrap .cal-tl-scroll::-webkit-scrollbar-track  { background: transparent; }
.cal-wrap .cal-tl-scroll::-webkit-scrollbar-thumb  { background: #ccc; border-radius: 3px; }

.cal-wrap .cal-tl-head,
.cal-wrap .cal-tl-allday,
.cal-wrap .cal-tl-body { display: flex; }

.cal-wrap .cal-tl-head   { background: var(--c-text); position: sticky; top: 0; z-index: 3; }
.cal-wrap .cal-tl-allday { background: var(--c-surface); border-bottom: 2px solid var(--c-border-c); position: sticky; top: 0; z-index: 2; }
.cal-wrap .cal-tl-body   { background: var(--c-surface); }

.cal-wrap .cal-tl-gutter,
.cal-wrap .cal-tl-allday-label,
.cal-wrap .cal-tl-hours {
    width: var(--c-gutter); min-width: var(--c-gutter); flex-shrink: 0; background: var(--c-surface);
}
.cal-wrap .cal-tl-gutter { border-right: 1px solid rgba(255,255,255,.2); background: transparent; }
.cal-wrap .cal-tl-allday-label,
.cal-wrap .cal-tl-hours { border-right: 1px solid var(--c-border-c); }
.cal-wrap .cal-tl-allday-label {
    display: flex; align-items: center; justify-content: center;
    font-size: .6rem; font-weight: 600; color: var(--c-muted);
}
.cal-wrap .cal-tl-hours { min-height: 72rem; }
.cal-wrap .cal-tl-hour {
    height: 3rem; font-size: .6rem; color: var(--c-muted);
    display: flex; align-items: flex-start; justify-content: center;
    padding-top: .12rem; border-bottom: 1px solid var(--c-border-c); box-sizing: border-box;
}

.cal-wrap .cal-week-head-cell,
.cal-wrap .cal-tl-allday-cell,
.cal-wrap .cal-tl-col { flex: 1; min-width: 0; border-right: 1px solid var(--c-border-c); }
.cal-wrap .cal-week-head-cell:last-child,
.cal-wrap .cal-tl-allday-cell:last-child,
.cal-wrap .cal-tl-col:last-child { border-right: none; }

.cal-wrap .cal-week-head-cell {
    position: relative; text-align: center; padding: .52rem .1rem;
    background: var(--c-text); color: #fff;
    font-size: .72rem; font-weight: 600;
    overflow: hidden; white-space: nowrap; text-overflow: ellipsis;
    border-right-color: rgba(255,255,255,.15);
}
.cal-wrap .cal-week-head-cell .wh-day   { display: block; }
.cal-wrap .cal-week-head-cell .wh-num   { display: block; font-family: var(--c-serif); font-size: 1.2rem; font-weight: 700; line-height: 1; margin-top: .04rem; }
.cal-wrap .cal-week-head-cell .wh-month { display: block; font-size: .6rem; opacity: .8; margin-top: .08rem; overflow: hidden; text-overflow: ellipsis; }
.cal-wrap .cal-week-head-cell.wh-today   { background: var(--c-accent); }
.cal-wrap .cal-week-head-cell.wh-weekend { opacity: .75; }

.cal-wrap .cal-tl-allday-cell { padding: .2rem .2rem; min-height: 1.8rem; overflow: hidden; }
.cal-wrap .cal-tl-allday-cell.wc-weekend { background: var(--c-wknd); }
.cal-wrap .cal-tl-col { position: relative; min-height: 72rem; overflow: hidden; }
.cal-wrap .cal-tl-col.wc-today   { background: var(--c-ev-bg); }
.cal-wrap .cal-tl-col.wc-weekend { background: var(--c-wknd); }
.cal-wrap .cal-tl-slot { height: 3rem; border-bottom: 1px solid var(--c-border-c); box-sizing: border-box; }

.cal-wrap .cal-tl-ev {
    position: absolute; left: 1px; right: 1px;
    background: #fff; border-left: 3px solid var(--c-ev-bd);
    border-radius: 3px; padding: .1rem .25rem;
    font-size: .65rem; line-height: 1.2; overflow: hidden;
    display: block; cursor: pointer; z-index: 1; transition: opacity .15s;
    white-space: nowrap; text-overflow: ellipsis;
}
.cal-wrap .cal-tl-ev:hover  { opacity: .8; }
.cal-wrap .cal-tl-ev-title  { font-weight: 600; display: block; overflow: hidden; text-overflow: ellipsis; color: var(--c-text); }
.cal-wrap .cal-tl-ev-time   { font-size: .58rem; color: var(--c-muted); display: block; }

/* ---- Vue Détail ---- */
.cal-wrap .cal-day-frame { padding: 1.3rem; }
.cal-wrap .cal-back-wrap { margin-bottom: 1rem; }
.cal-wrap .cal-back-btn {
    display: inline-block; padding: .3rem .8rem; border-radius: 20px;
    border: 1.5px solid var(--c-border-c);
    font-size: .8rem; font-weight: 600; color: var(--c-accent2); transition: all .15s;
}
.cal-wrap .cal-back-btn:hover { background: var(--c-accent2); border-color: var(--c-accent2); color: #fff; }
.cal-wrap .cal-day-card { border-left: 5px solid var(--c-ev-bd); padding-left: .95rem; }
.cal-wrap .cal-day-card + .cal-day-card { margin-top: 1.25rem; padding-top: 1.25rem; border-top: 1px solid var(--c-border-c); }
.cal-wrap .cal-day-card h3 { font-family: var(--c-serif); font-size: 1.18rem; margin: 0 0 .32rem; }
.cal-wrap .cal-day-card .ev-meta { display: flex; gap: .85rem; flex-wrap: wrap; font-size: .78rem; color: var(--c-muted); margin-bottom: .65rem; }
.cal-wrap .cal-day-card .ev-meta span { display: flex; align-items: center; gap: .22rem; }
.cal-wrap .cal-day-card .ev-body { font-size: .89rem; line-height: 1.65; border-top: 1px solid var(--c-border-c); padding-top: .65rem; margin-top: .65rem; }
.cal-wrap .cal-day-card .ev-body a       { color: var(--c-accent); text-decoration: underline; }
.cal-wrap .cal-day-card .ev-body a:hover { color: var(--c-accent2); }
.cal-wrap .cal-day-card .ev-body img     { max-width: 100%; border-radius: 6px; margin: .38rem 0; }
.cal-wrap .cal-no-ev { text-align: center; padding: 2.2rem 1rem; color: var(--c-muted); font-style: italic; }

/* ---- Responsive ---- */
@media (max-width: 680px) {
    .cal-wrap .cal-day                 { min-height: 42px; padding: .18rem; }
    .cal-wrap .cal-ev-item .ev-extrait { display: none; }
    .cal-wrap .cal-annual              { grid-template-columns: repeat(2, 1fr); }
    .cal-wrap .cal-nav .cal-period     { min-width: 70px; }
    .cal-wrap .cal-tl-scroll           { height: 360px; }
    .cal-wrap .cal-tl-gutter,
    .cal-wrap .cal-tl-allday-label,
    .cal-wrap .cal-tl-hours            { width: 2.2rem; min-width: 2.2rem; }
    .cal-wrap .cal-tl-hour             { font-size: .52rem; }
    .cal-wrap .cal-week-head-cell      { font-size: .62rem; padding: .35rem .05rem; }
    .cal-wrap .cal-week-head-cell .wh-num   { font-size: 1rem; }
    .cal-wrap .cal-week-head-cell .wh-month { display: none; }
    .cal-wrap .cal-week-head-cell           { overflow: visible; }
    .cal-wrap .cal-write-head { position: absolute; top: .2rem; right: .2rem; transform: none; background: none; }
    /* Espace réservé pour la croix uniquement quand elle est présente */
    .cal-wrap .cal-week-head-cell.has-write { padding-top: 1.4rem; }
    /* Cercles parfaits en vue annuelle */
    .cal-wrap .cal-mini-day { width: min(1.6rem, 100%); aspect-ratio: 1; height: auto; max-width: 1.6rem; }
    .cal-wrap .cal-btn { padding: .2rem .45rem; font-size: .75rem; }
}
@media (max-width: 480px) {
    .cal-wrap .cal-controls { justify-content: center; }
    .cal-wrap .cal-nav      { justify-content: center; width: 100%; }
}
