/* ── Variables ─────────────────────────────────────────────────────────────── */
:root {
    --lcr-color-primary:   #3a6f4c;
    --lcr-color-confirm:   #2e7d32;
    --lcr-color-cancel:    #c0392b;
    --lcr-color-neutral:   #555;
    --lcr-color-bg:        #fafaf8;
    --lcr-color-border:    #ddd;
    --lcr-color-pending:   #e67e22;
    --lcr-color-confirmed: #27ae60;
    --lcr-color-cancelled: #95a5a6;
    --lcr-radius:          6px;
    --lcr-font:            inherit;
}

/* ── Layout général ────────────────────────────────────────────────────────── */
.lcr-form-wrap,
.lcr-dashboard {
    font-family: var(--lcr-font);
    max-width: 860px;
    margin: 0 auto;
}

/* ── Jour de la semaine à côté de la date ───────────────────────────────────── */
.lcr-date-dow {
    font-weight: 400;
    font-size: .8rem;
    color: var(--lcr-color-primary);
    font-style: italic;
    text-transform: none;
    letter-spacing: 0;
}

/* ── Date picker custom ────────────────────────────────────────────────────── */
.lcr-field--date { position: relative; }

.lcr-datepicker-trigger {
    display: block;
    width: 100%;
    padding: 10px 14px;
    border: 1.5px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    background: #fff;
    font-size: .95rem;
    font-family: inherit;
    color: #333;
    text-align: left;
    cursor: pointer;
    transition: border-color .2s;
}

.lcr-datepicker-trigger:hover { border-color: var(--lcr-color-primary); }

.lcr-datepicker {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 100;
    background: #fff;
    border: 1.5px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
    padding: 12px;
    margin-top: 4px;
}

.lcr-dp-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.lcr-dp-title {
    font-weight: 700;
    font-size: .9rem;
    color: #333;
}

.lcr-dp-nav {
    background: none;
    border: 1px solid var(--lcr-color-border);
    border-radius: 50%;
    width: 28px;
    height: 28px;
    font-size: 1.1rem;
    cursor: pointer;
    color: #555;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .15s;
}

.lcr-dp-nav:hover { background: #f5f5f5; }

.lcr-dp-grid {
    width: 100%;
    border-collapse: collapse;
}

.lcr-dp-grid th {
    font-size: .7rem;
    font-weight: 600;
    color: #999;
    text-transform: uppercase;
    padding: 4px 0;
    text-align: center;
}

.lcr-dp-grid td {
    text-align: center;
    padding: 2px;
}

.lcr-dp-day {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    font-size: .82rem;
    font-weight: 600;
    border: none;
    background: none;
    cursor: pointer;
    transition: background .15s, color .15s;
}

.lcr-dp-day--open {
    color: #1b7a3d;
    background: #e8f5e9;
}

.lcr-dp-day--open:hover {
    background: #1b7a3d;
    color: #fff;
}

.lcr-dp-day--closed {
    color: #c0392b;
    background: #fde8e8;
    cursor: not-allowed;
}

.lcr-dp-day--past {
    color: #ccc;
    cursor: not-allowed;
}

.lcr-dp-day--selected {
    background: var(--lcr-color-primary) !important;
    color: #fff !important;
}

@media (max-width: 600px) {
    .lcr-dp-day { width: 28px; height: 28px; font-size: .75rem; }
}

/* ── Case "pas de téléphone" ───────────────────────────────────────────────── */
.lcr-no-phone-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.5rem;
    font-size: 0.82rem;
    color: #666;
    cursor: pointer;
    font-weight: normal;
    text-transform: none;
    letter-spacing: 0;
}

.lcr-no-phone-label input[type=checkbox] {
    accent-color: var(--lcr-color-primary);
    width: 15px;
    height: 15px;
    flex-shrink: 0;
    cursor: pointer;
}

/* ── Validation email ──────────────────────────────────────────────────────── */
.lcr-email-error {
    display: block;
    font-size: 0.78rem;
    color: #c0392b;
    margin-top: 4px;
}

/* ── Champs ────────────────────────────────────────────────────────────────── */
.lcr-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 16px;
}

.lcr-field label {
    font-size: .875rem;
    font-weight: 600;
    color: var(--lcr-color-neutral);
}

.lcr-field input {
    padding: 9px 12px;
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    font-size: 1rem;
    background: #fff;
    width: 100%;
    box-sizing: border-box;
}

.lcr-field input[readonly] {
    background: #f0f0f0;
    color: var(--lcr-color-neutral);
    cursor: default;
}

.lcr-field select {
    padding: 9px 12px;
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    font-size: 1rem;
    background: #fff;
    width: 100%;
    box-sizing: border-box;
}

.lcr-field select:focus {
    outline: none;
    border-color: var(--lcr-color-primary);
    box-shadow: 0 0 0 3px rgba(58,111,76,.15);
}

.lcr-field input:focus {
    outline: none;
    border-color: var(--lcr-color-primary);
    box-shadow: 0 0 0 3px rgba(58,111,76,.15);
}

.lcr-field-row {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

.lcr-field-row .lcr-field {
    flex: 1 1 140px;
}

/* ── Boutons ───────────────────────────────────────────────────────────────── */
.lcr-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border: none;
    border-radius: var(--lcr-radius);
    font-size: .875rem;
    font-weight: 600;
    cursor: pointer;
    transition: opacity .15s;
}

.lcr-btn:disabled { opacity: .5; cursor: not-allowed; }
.lcr-btn:hover:not(:disabled) { opacity: .85; }

.lcr-btn--primary   { background: var(--lcr-color-primary);  color: #fff !important; text-decoration: none !important; }
.lcr-btn--primary:hover { color: #fff !important; text-decoration: none !important; opacity: .9; }
.lcr-btn--secondary { background: #e8f5e9; color: var(--lcr-color-primary); }
.lcr-btn--outline   { background: transparent; color: var(--lcr-color-primary); border: 2px solid var(--lcr-color-primary); }
.lcr-btn--ghost     { background: transparent; color: var(--lcr-color-neutral); border: 1px solid var(--lcr-color-border); }
.lcr-btn--confirm   { background: var(--lcr-color-confirm);  color: #fff; font-size: .8rem; padding: 5px 10px; }
.lcr-btn--cancel    { background: var(--lcr-color-cancel);   color: #fff; font-size: .8rem; padding: 5px 10px; }
.lcr-btn--delete    { background: #333; color: #fff; font-size: .8rem; padding: 5px 10px; }

/* ── Notices ───────────────────────────────────────────────────────────────── */
.lcr-notice {
    padding: 12px 16px;
    border-radius: var(--lcr-radius);
    margin-bottom: 16px;
    font-size: .9rem;
}

.lcr-notice--success { background: #e8f5e9; color: var(--lcr-color-confirm); border-left: 4px solid var(--lcr-color-confirm); }
.lcr-notice--error   { background: #ffebee; color: var(--lcr-color-cancel);  border-left: 4px solid var(--lcr-color-cancel); }
.lcr-notice p        { margin: 4px 0; }

/* ── Disponibilité formulaire public ──────────────────────────────────────── */
.lcr-availability-info { margin: 0 0 16px; }
.lcr-avail { padding: 10px 14px; border-radius: var(--lcr-radius); font-size: .9rem; line-height: 1.5; }
.lcr-avail--ok     { background: #e8f5e9; color: var(--lcr-color-confirm); border-left: 4px solid var(--lcr-color-confirm); }
.lcr-avail--full   { background: #ffebee; color: var(--lcr-color-cancel);  border-left: 4px solid var(--lcr-color-cancel); }
.lcr-avail--closed { background: #fff3e0; color: #e65100;                  border-left: 4px solid #e65100; }

/* ── Titre du jour ─────────────────────────────────────────────────────────── */
.lcr-dashboard__topbar {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.lcr-dashboard__topbar-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
    margin-left: auto;
}

.lcr-day-title {
    display: inline-block;
    font-size: 1.3rem;
    font-weight: 700;
    margin: 0;
    color: #fff;
    text-transform: capitalize;
    background: #c0392b;
    padding: .35em .8em;
    border-radius: 6px;
    line-height: 1.3;
}

.lcr-today-badge {
    font-size: .65rem;
    font-weight: 600;
    color: rgba(255,255,255,.85);
    text-transform: lowercase;
    letter-spacing: .04em;
    vertical-align: middle;
    margin-left: 8px;
}

/* ── Fermeture ─────────────────────────────────────────────────────────────── */
.lcr-closure-wrap {
    margin-bottom: 12px;
}

.lcr-btn--danger {
    background: var(--lcr-color-cancel);
    color: #fff;
}

.lcr-closed-label {
    font-size: 1.4rem;
    font-weight: 800;
    color: var(--lcr-color-cancel);
    text-transform: uppercase;
    letter-spacing: .1em;
    padding: 8px 0;
}

.lcr-dashboard--closed .lcr-add-wrap {
    opacity: .5;
    pointer-events: none;
}

/* ── Date passée ───────────────────────────────────────────────────────────── */
.lcr-dashboard--past .lcr-gauge-wrap,
.lcr-dashboard--past .lcr-add-wrap,
.lcr-dashboard--past .lcr-closure-wrap {
    opacity: .45;
    pointer-events: none;
}

.lcr-dashboard--past .lcr-day-title {
    background: #888;
}

.lcr-dashboard--past .lcr-day-title::after {
    content: ' — archive';
    font-size: .55em;
    font-weight: 400;
    color: rgba(255,255,255,.7);
    vertical-align: middle;
    margin-left: 6px;
}

/* ── Dashboard – navigation date ───────────────────────────────────────────── */
.lcr-dashboard__nav {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
}

.lcr-date-dow {
    font-size: .85rem;
    font-weight: 600;
    color: var(--lcr-color-primary);
    text-transform: capitalize;
}

.lcr-today-link {
    background: none;
    border: none;
    color: var(--lcr-color-neutral);
    font-size: .75rem;
    cursor: pointer;
    padding: 4px 6px;
    opacity: .6;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.lcr-today-link:hover { opacity: 1; }

/* ── Jauge inline (dans la barre nav) ─────────────────────────────────────── */
.lcr-gauge-edit-inline {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    margin-bottom: 12px;
}

.lcr-admin-links {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}

.lcr-admin-links__sep {
    color: #ccc;
    font-size: .8rem;
}

.lcr-closure-panel {
    margin-bottom: 12px;
    padding: 12px 16px;
    background: #fafaf8;
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
}

.lcr-closure-panel .lcr-day-status {
    margin-bottom: 8px;
}

.lcr-closure-panel .lcr-closure-wrap {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.lcr-btn--closure-open {
    background: var(--lcr-color-primary);
    color: #fff;
    border: none;
    font-weight: 600;
}

.lcr-btn--closure-open:hover {
    background: #2e5a3a;
}

.lcr-btn--closure-closed {
    background: var(--lcr-color-cancel);
    color: #fff;
    border: none;
    font-weight: 600;
}

.lcr-btn--closure-closed:hover {
    background: #a03020;
}

.lcr-gauge-edit-inline__toggle {
    background: none;
    border: none;
    font-size: .78rem;
    color: var(--lcr-color-primary);
    cursor: pointer;
    padding: 0;
    text-decoration: underline;
    text-underline-offset: 2px;
    white-space: nowrap;
    transition: color .2s;
}

.lcr-gauge-edit-inline__toggle:hover {
    color: #1a1a1a;
}

.lcr-gauge-edit-inline__row {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 12px;
    padding: 12px 16px;
    background: #fafaf8;
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
}

.lcr-gauge-edit-inline__svc-label {
    font-size: .8rem;
    font-weight: 700;
    color: #555;
    white-space: nowrap;
}

.lcr-gauge-edit-inline__input {
    width: 72px;
    padding: 8px 10px;
    border: 2px solid var(--lcr-color-primary);
    border-radius: var(--lcr-radius);
    font-size: 1rem;
    font-weight: 700;
    text-align: center;
    color: #1a1a1a;
    background: #fff;
}

.lcr-gauge-edit-inline__input:focus {
    border-color: var(--lcr-color-primary);
    outline: none;
    box-shadow: 0 0 0 3px rgba(58,90,64,.15);
}

.lcr-gauge-edit-inline__btn {
    padding: 6px 12px !important;
    font-size: .8rem !important;
    font-weight: 700 !important;
    min-height: auto !important;
}

.lcr-dashboard__nav input[type=date] {
    padding: 8px 12px;
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    font-size: 1rem;
    flex: 1;
    max-width: 200px;
}

/* ── Jauge ─────────────────────────────────────────────────────────────────── */
.lcr-gauge-wrap {
    background: var(--lcr-color-bg);
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    padding: 20px;
    margin-bottom: 24px;
    display: flex;
    gap: 32px;
    flex-wrap: wrap;
    align-items: flex-start;
}

.lcr-gauge {
    flex: 1 1 200px;
}

.lcr-gauge__label {
    display: block;
    font-size: .8rem;
    color: var(--lcr-color-neutral);
    text-transform: uppercase;
    letter-spacing: .05em;
    margin-bottom: 4px;
}

.lcr-gauge__value {
    display: block;
    font-size: 1.75rem;
    font-weight: 700;
    margin-bottom: 8px;
    color: #1a1a1a;
}

.lcr-gauge__bar {
    height: 10px;
    background: #e0e0e0;
    border-radius: 99px;
    overflow: hidden;
}

.lcr-gauge__fill {
    height: 100%;
    background: var(--lcr-color-confirmed);
    border-radius: 99px;
    transition: width .3s ease;
}

.lcr-gauge__fill--danger { background: var(--lcr-color-cancel); }

.lcr-gauge-edit {
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.lcr-gauge-edit label {
    font-size: .8rem;
    color: var(--lcr-color-neutral);
}

.lcr-gauge-edit__row {
    display: flex;
    gap: 8px;
    align-items: center;
}

.lcr-gauge-edit input[type=number] {
    width: 80px;
    padding: 7px 10px;
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    font-size: 1rem;
}

/* ── Formulaire ajout manuel ────────────────────────────────────────────────── */
.lcr-add-wrap {
    margin-bottom: 24px;
}

.lcr-add-form {
    background: var(--lcr-color-bg);
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    padding: 20px;
    margin-top: 12px;
}

/* ── Navigation service ────────────────────────────────────────────────────── */
.lcr-service-tabs {
    display: flex;
    gap: 0;
    margin-bottom: 20px;
    border: 2px solid #ddd;
}

.lcr-service-tab {
    flex: 1;
    padding: 14px 16px;
    font-size: 1rem;
    font-weight: 700;
    border: 2px solid var(--lcr-color-border);
    background: #fafaf8;
    color: #555;
    cursor: pointer;
    transition: background .2s, color .2s, border-color .2s;
}

.lcr-service-tab:first-child {
    border-radius: 8px 0 0 8px;
    border-right: 1px solid var(--lcr-color-border);
}

.lcr-service-tab:last-child {
    border-radius: 0 8px 8px 0;
    border-left: 1px solid var(--lcr-color-border);
}

.lcr-service-tab--midi.lcr-service-tab--active {
    background: #fff8e1;
    color: #e65100;
    border-color: #ffb300;
}

.lcr-service-tab--soir.lcr-service-tab--active {
    background: #e8eaf6;
    color: #283593;
    border-color: #5c6bc0;
}

.lcr-service-tab:hover:not(.lcr-service-tab--active) {
    background: #f0ede6;
}

.lcr-day-status {
    display: flex;
    gap: 12px;
    margin-bottom: 12px;
}

.lcr-day-status__item {
    font-size: .75rem;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 6px;
}

.lcr-day-status__item--open {
    background: #e8f5e9;
    color: #2e7d32;
}

.lcr-day-status__item--closed {
    background: #fce4ec;
    color: #c62828;
}

.lcr-btn--danger {
    background: #e53935 !important;
    color: #fff !important;
    border-color: #e53935 !important;
}

.lcr-service-panel {
    margin-bottom: 24px;
}

.lcr-panel--closed .lcr-add-wrap {
    opacity: .5;
    pointer-events: none;
}

/* Sélecteur service (formulaire public) */
.lcr-service-toggle {
    display: flex;
    gap: 12px;
}

.lcr-service-option {
    display: flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    font-weight: 600;
}

.lcr-service-option input[type=radio] { accent-color: var(--lcr-color-primary); }

/* ── Sélecteur de couverts ─────────────────────────────────────────────────── */
.lcr-covers-selector {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.lcr-covers-option {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.lcr-covers-option input[type=radio] { display: none; }

.lcr-covers-option span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border: 2px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    font-size: .95rem;
    font-weight: 600;
    color: var(--lcr-color-neutral);
    transition: border-color .15s, background .15s, color .15s;
}

.lcr-covers-option input[type=radio]:checked + span {
    border-color: var(--lcr-color-primary);
    background: var(--lcr-color-primary);
    color: #fff;
}

.lcr-covers-option:hover span {
    border-color: var(--lcr-color-primary);
    color: var(--lcr-color-primary);
}

.lcr-covers-free {
    width: 72px;
    padding: 7px 10px;
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    font-size: .95rem;
}

.lcr-checkbox-label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .8rem;
    color: var(--lcr-color-neutral);
    margin-top: 6px;
    cursor: pointer;
}

.lcr-checkbox-label input[type=checkbox] {
    accent-color: var(--lcr-color-primary);
    width: auto;
}

.lcr-inline-check {
    font-size: .75rem;
    font-weight: 400;
    color: var(--lcr-color-neutral);
    margin-left: 8px;
    cursor: pointer;
    opacity: .8;
}

.lcr-inline-check input[type=checkbox] {
    accent-color: var(--lcr-color-primary);
    width: auto;
    margin-right: 3px;
    vertical-align: middle;
}

.lcr-no-phone {
    color: var(--lcr-color-neutral);
    font-style: italic;
    font-size: .85em;
}

/* ── Tableau des réservations ──────────────────────────────────────────────── */
.lcr-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .9rem;
}

.lcr-table th,
.lcr-table td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--lcr-color-border);
    text-align: left;
    vertical-align: middle;
    color: #000;
}

.lcr-table th {
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--lcr-color-neutral);
    background: var(--lcr-color-bg);
    border-bottom: 2px solid var(--lcr-color-border);
}

.lcr-table thead tr th:first-child { border-left: none; }
.lcr-table thead tr th:last-child  { border-right: none; }

.lcr-row--cancelled td { opacity: .55; }

.lcr-row--svc-midi td { background: #fff8eb; }
.lcr-row--svc-soir td { background: #eef0fa; }
.lcr-row--svc-midi td:first-child { border-left: 4px solid #e6a817; }
.lcr-row--svc-soir td:first-child { border-left: 4px solid #4a5fa0; }

.lcr-svc-divider {
    font-size: .8rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
    padding: 10px 14px !important;
    border: none !important;
}

.lcr-svc-divider small {
    font-weight: 700;
    opacity: 1;
    margin-left: 6px;
    background: rgba(255,255,255,.25);
    padding: 2px 8px;
    border-radius: 4px;
    font-size: .72rem;
}

.lcr-svc-divider--midi {
    background: #e6a817;
    color: #fff;
}

.lcr-svc-divider--soir {
    background: #4a5fa0;
    color: #fff;
}

.lcr-row--svc-header-soir td {
    padding-top: 20px !important;
}

/* ── Vue mois synthétique ──────────────────────────────────────────────── */
.lcr-month-summary {
    margin-bottom: 20px;
    padding: 20px;
    background: #fff;
    border-radius: 12px;
}

.lcr-month-summary__stats {
    display: flex;
    gap: 12px;
    margin-bottom: 16px;
}

.lcr-month-summary__stat {
    flex: 1;
    text-align: center;
    padding: 10px;
    background: #f8f8f6;
    border-radius: 8px;
}

.lcr-month-summary__stat--midi { background: #fff8eb; border: 1px solid #f0dfc0; }
.lcr-month-summary__stat--soir { background: #eef0fa; border: 1px solid #d0d6e8; }

.lcr-month-summary__num {
    display: block;
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--lcr-color-dark, #222);
    line-height: 1;
    margin-bottom: 4px;
}

.lcr-month-summary__stat--midi .lcr-month-summary__num { color: #c08820; }
.lcr-month-summary__stat--soir .lcr-month-summary__num { color: #4a5fa0; }

.lcr-month-summary__label {
    font-size: .68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--lcr-color-neutral);
}

.lcr-month-summary__bar-wrap {
    margin-top: 4px;
}

.lcr-month-summary__bar {
    height: 16px;
    background: #f0f0ee;
    border-radius: 8px;
    overflow: hidden;
    display: flex;
    margin-bottom: 6px;
}

.lcr-month-summary__fill--midi { background: #e6a817; }
.lcr-month-summary__fill--soir { background: #4a5fa0; }

.lcr-month-summary__pct {
    font-size: .78rem;
    color: var(--lcr-color-neutral);
    text-align: center;
}

@media (max-width: 480px) {
    .lcr-month-summary__stats { flex-direction: column; gap: 8px; }
    .lcr-month-summary__num { font-size: 1.3rem; }
}

.lcr-month-grid {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.lcr-month-day {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: #fff;
    border-radius: 8px;
    border: 1px solid #eee;
    text-decoration: none;
    color: inherit;
    transition: background .15s;
}

.lcr-month-day:hover { background: #f8f8f6; }

.lcr-month-day--today {
    border-color: var(--lcr-color-primary);
    border-width: 2px;
    background: #f0f8f3;
}

.lcr-month-day--past { opacity: .45; }

.lcr-month-day--closed {
    background: #fafafa;
}

.lcr-month-day__label {
    width: 42px;
    flex-shrink: 0;
    font-size: .78rem;
    color: var(--lcr-color-neutral);
}

.lcr-month-day__label strong {
    color: var(--lcr-color-dark, #222);
    font-size: .9rem;
}

.lcr-month-day__status {
    font-size: .72rem;
    color: #bbb;
    font-style: italic;
}

.lcr-month-day__svc {
    display: flex;
    align-items: center;
    gap: 4px;
    flex: 1;
    min-width: 0;
}

.lcr-month-day__svc--off { opacity: .3; }

.lcr-month-day__svc-label {
    font-size: .7rem;
    width: 16px;
    text-align: center;
    flex-shrink: 0;
}

.lcr-month-day__bar {
    flex: 1;
    height: 4px;
    background: #eee;
    border-radius: 2px;
    overflow: hidden;
    min-width: 20px;
    max-width: 60px;
}

.lcr-month-day__fill {
    height: 100%;
    border-radius: 4px;
    transition: width .3s;
}

.lcr-month-day__fill--midi { background: #e6a817; }
.lcr-month-day__fill--soir { background: #4a5fa0; }

.lcr-month-bar--high { background: #e67e22 !important; }
.lcr-month-bar--full { background: #e53935 !important; }

.lcr-month-day__val {
    font-size: .68rem;
    font-weight: 700;
    color: #666;
    width: 45px;
    text-align: right;
    flex-shrink: 0;
}

@media (max-width: 480px) {
    .lcr-month-day { padding: 6px 8px; gap: 6px; }
    .lcr-month-day__label { width: 32px; }
    .lcr-month-day__val { width: 38px; font-size: .62rem; }
}

.lcr-syn-detail-btn {
    display: inline-block;
    margin-left: 10px;
    padding: 4px 12px;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-decoration: none;
    color: #fff;
    background: var(--lcr-color-primary, #2e7d32);
    border-radius: 6px;
    vertical-align: middle;
    transition: background .2s;
}

.lcr-syn-detail-btn:hover {
    background: var(--lcr-color-primary-dark, #1b5e20);
    color: #fff;
}

.lcr-row--subtotal td {
    background: #f5f5f3 !important;
    border-top: 2px solid #ddd;
    font-size: .8rem;
    color: var(--lcr-color-neutral);
    padding: 8px 10px !important;
}

.lcr-td-ref {
    font-size: .7rem;
    color: #aaa;
    font-family: monospace;
    letter-spacing: .04em;
}

/* ── Toggle colonnes ────────────────────────────────────────────────────────── */
.lcr-col-toggle {
    position: relative;
    display: inline-block;
    float: right;
}

.lcr-col-toggle__btn {
    background: none;
    border: 1.5px solid var(--lcr-color-border);
    border-radius: 6px;
    padding: 5px 12px;
    font-size: .75rem;
    font-weight: 600;
    color: var(--lcr-color-neutral);
    cursor: pointer;
    transition: border-color .15s;
}

.lcr-col-toggle__btn:hover { border-color: var(--lcr-color-primary); color: var(--lcr-color-primary); }

.lcr-col-toggle__panel {
    position: absolute;
    top: 100%;
    right: 0;
    z-index: 9999;
    background: #fff;
    border: 1.5px solid var(--lcr-color-border);
    border-radius: 8px;
    padding: 8px 4px;
    margin-top: 4px;
    box-shadow: 0 4px 16px rgba(0,0,0,.1);
    min-width: 150px;
}

@media (max-width: 600px) {
    .lcr-col-toggle__panel {
        position: fixed;
        top: 50%;
        left: 50%;
        right: auto;
        transform: translate(-50%, -50%);
        min-width: 200px;
        max-width: 260px;
        padding: 12px 8px;
        border-radius: 12px;
        box-shadow: 0 8px 40px rgba(0,0,0,.25);
    }
}

.lcr-col-toggle__item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px 10px;
    font-size: .8rem;
    color: #333;
    cursor: pointer;
    border-radius: 4px;
    transition: background .1s;
}

.lcr-col-toggle__item:hover { background: #f5f5f5; }

.lcr-col-toggle__item input[type=checkbox] {
    width: 14px;
    height: 14px;
    accent-color: var(--lcr-color-primary);
}

/* Classes de masquage colonnes */
.lcr-hide-col-ref [data-col="ref"],
.lcr-hide-col-heure [data-col="heure"],
.lcr-hide-col-source [data-col="source"],
.lcr-hide-col-saisi [data-col="saisi"],
.lcr-hide-col-valide [data-col="valide"],
.lcr-hide-col-actions [data-col="actions"],
.lcr-hide-col-tel [data-col="tel"],
.lcr-hide-col-email [data-col="email"],
.lcr-hide-col-remarque [data-col="remarque"],
.lcr-hide-col-places [data-col="places"],
.lcr-hide-col-lang [data-col="lang"] {
    display: none !important;
}

/* Boutons compacts */
.lcr-btn--xs {
    padding: 4px 10px !important;
    font-size: .75rem !important;
    min-width: 0 !important;
}

/* Tableau scrollable horizontalement */
.lcr-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.lcr-table { table-layout: auto; min-width: 900px; }

.lcr-table th, .lcr-table td { font-size: .78rem; padding: 6px 6px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lcr-table td[data-col="nom"] { white-space: normal; }

.lcr-table th[data-col="ref"],
.lcr-table td[data-col="ref"]       { width: 8%; }

.lcr-table th[data-col="heure"],
.lcr-table td[data-col="heure"]     { width: 5%; }

.lcr-table th[data-col="nom"],
.lcr-table td[data-col="nom"]       { width: auto; word-wrap: break-word; overflow-wrap: break-word; white-space: normal; }

.lcr-table th[data-col="service"],
.lcr-table td[data-col="service"]   { width: 6%; }

.lcr-table th[data-col="couv"],
.lcr-table td[data-col="couv"]      { width: 5%; text-align: center; }

.lcr-table th[data-col="statut"],
.lcr-table td[data-col="statut"]    { width: 10%; }

.lcr-table th[data-col="source"],
.lcr-table td[data-col="source"]    { width: 5%; text-align: center; }

.lcr-table th[data-col="saisi"],
.lcr-table td[data-col="saisi"]     { width: 7%; }

.lcr-table th[data-col="valide"],
.lcr-table td[data-col="valide"]    { width: 7%; }

.lcr-table th[data-col="places"],
.lcr-table td[data-col="places"]    { width: 5%; text-align: center; }

.lcr-table th[data-col="lang"],
.lcr-table td[data-col="lang"]      { width: 4%; text-align: center; }

.lcr-table th[data-col="tel"],
.lcr-table td[data-col="tel"]       { width: 10%; }

.lcr-table th[data-col="email"],
.lcr-table td[data-col="email"]     { width: 14%; }

.lcr-table th[data-col="actions"],
.lcr-table td[data-col="actions"]   { width: auto; white-space: nowrap; }

.lcr-row-remarque td { border-bottom: 1px solid var(--lcr-color-border); }

.lcr-remarque-inline {
    display: block;
    font-size: .78rem;
    font-style: italic;
    color: #c0392b;
    margin-top: 2px;
    line-height: 1.3;
}

.lcr-actions { white-space: nowrap; }
.lcr-actions .lcr-btn { margin-right: 4px; }

/* ── Statuts ───────────────────────────────────────────────────────────────── */
.lcr-status {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 99px;
    font-size: .75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    white-space: nowrap;
}

.lcr-status--pending   { background: #fff3e0; color: var(--lcr-color-pending); }
.lcr-status--confirmed { background: #e8f5e9; color: var(--lcr-color-confirmed); }
.lcr-status--cancelled { background: #f5f5f5; color: var(--lcr-color-cancelled); }

/* ── Picto info ────────────────────────────────────────────────────────────── */
.lcr-info-btn {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 1rem;
    color: var(--lcr-color-primary);
    opacity: .7;
    padding: 0 2px;
    vertical-align: middle;
    line-height: 1;
}

.lcr-info-btn:hover { opacity: 1; }

/* ── Modal ─────────────────────────────────────────────────────────────────── */
.lcr-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.45);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}

.lcr-modal {
    background: #fff;
    border-radius: var(--lcr-radius);
    padding: 28px 32px;
    min-width: 320px;
    max-width: 480px;
    width: 90%;
    position: relative;
    box-shadow: 0 8px 32px rgba(0,0,0,.18);
}

.lcr-modal__close {
    position: absolute;
    top: 12px;
    right: 16px;
    background: none;
    border: none;
    font-size: 1.4rem;
    cursor: pointer;
    color: var(--lcr-color-neutral);
    line-height: 1;
}

.lcr-modal__close:hover { color: #000; }

.lcr-modal__title {
    margin: 0 0 20px;
    font-size: 1.15rem;
    font-weight: 700;
    color: #1a1a1a;
}

.lcr-modal__body { margin: 0; }

.lcr-modal__row {
    display: flex;
    gap: 12px;
    padding: 7px 0;
    border-bottom: 1px solid var(--lcr-color-border);
    align-items: baseline;
}

.lcr-modal__row:last-child { border-bottom: none; }

.lcr-modal__row dt {
    flex: 0 0 100px;
    font-size: .8rem;
    font-weight: 600;
    color: var(--lcr-color-neutral);
    text-transform: uppercase;
    letter-spacing: .04em;
}

.lcr-modal__row dd {
    margin: 0;
    font-size: .95rem;
    color: #1a1a1a;
    word-break: break-word;
}

/* ── Textarea ──────────────────────────────────────────────────────────────── */
.lcr-field textarea {
    padding: 9px 12px;
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    font-size: 1rem;
    font-family: inherit;
    background: #fff;
    width: 100%;
    box-sizing: border-box;
    resize: vertical;
}

.lcr-field textarea:focus {
    outline: none;
    border-color: var(--lcr-color-primary);
    box-shadow: 0 0 0 3px rgba(58,111,76,.15);
}

/* ── États vides / chargement ──────────────────────────────────────────────── */
.lcr-empty,
.lcr-loading {
    text-align: center;
    padding: 40px;
    color: var(--lcr-color-neutral);
    font-size: .95rem;
}

/* ── Responsive ────────────────────────────────────────────────────────────── */

/* ── Tablette (≤ 768px) ──────────────────────────────────────────────────── */
@media (max-width: 768px) {

    /* Cibles tactiles : tous les boutons min 44px */
    .lcr-btn {
        min-height: 44px;
        padding: 10px 18px;
    }

    .lcr-btn--confirm,
    .lcr-btn--cancel,
    .lcr-btn--delete,
    .lcr-btn--secondary {
        min-height: 40px;
        font-size: .8rem;
        padding: 8px 12px;
    }

    /* Dans les tableaux, boutons encore plus compacts */
    .lcr-table .lcr-btn--confirm,
    .lcr-table .lcr-btn--cancel,
    .lcr-table .lcr-btn--delete,
    .lcr-table .lcr-btn--secondary {
        min-height: 36px;
        font-size: .72rem;
        padding: 6px 10px;
    }

    /* Bouton info (ⓘ) */
    .lcr-info-btn {
        min-width: 44px;
        min-height: 44px;
        font-size: 1.2rem;
        padding: 0 8px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    /* Lien Aujourd'hui */
    .lcr-today-link {
        min-height: 44px;
        padding: 10px 10px;
        display: inline-flex;
        align-items: center;
        font-size: .85rem;
    }

    /* ── Navigation date ──────────────────────────────────────────────────── */
    .lcr-dashboard__nav {
        flex-wrap: wrap;
        gap: 8px;
    }

    .lcr-dashboard__nav input[type=date] {
        max-width: 100%;
        flex: 1 1 140px;
        min-height: 44px;
        font-size: 1rem;
    }

    .lcr-back-link--right {
        margin-left: 0;
        width: 100%;
        order: 10;
    }

    /* ── Boutons nav date (←/→) ───────────────────────────────────────────── */
    #lcr-prev-day,
    #lcr-next-day {
        min-width: 44px;
        min-height: 44px;
        font-size: 1.2rem;
        padding: 0 12px;
    }

    /* ── Navigation service ───────────────────────────────────────────────── */
    .lcr-service-tab {
        padding: 10px 12px;
        font-size: .85rem;
    }

    /* ── Jauge ────────────────────────────────────────────────────────────── */
    .lcr-gauge-wrap {
        flex-direction: column;
        gap: 16px;
        padding: 16px;
    }

    .lcr-gauge { flex: 1 1 auto; }

    .lcr-gauge-edit {
        flex: 1 1 auto;
        width: 100%;
    }

    .lcr-gauge-edit__row { flex-wrap: wrap; }

    .lcr-gauge-edit input[type=number] {
        flex: 1;
        width: auto;
        min-height: 44px;
    }

    /* ── Bouton fermeture modale d'édition ────────────────────────────────── */
    .lcr-modal__close {
        min-width: 44px;
        min-height: 44px;
        display: flex;
        align-items: center;
        justify-content: center;
        top: 8px;
        right: 8px;
        font-size: 1.6rem;
    }
}

/* ── Mobile (≤ 600px) ────────────────────────────────────────────────────── */
@media (max-width: 600px) {

    /* ── Tableau des réservations → card layout ───────────────────────────── */
    .lcr-table { table-layout: auto !important; }
    .lcr-table thead { display: none; }

    .lcr-table tr {
        display: block;
        border: 1px solid var(--lcr-color-border);
        border-radius: var(--lcr-radius);
        margin-bottom: 12px;
        padding: 10px 12px;
        background: #fff;
        text-align: left;
    }

    .lcr-table tr:last-child { border-bottom: 1px solid var(--lcr-color-border); }

    .lcr-table td {
        display: flex;
        align-items: baseline;
        justify-content: flex-start;
        text-align: left;
        gap: 8px;
        border: none;
        padding: 5px 0;
        border-bottom: 1px solid #f0f0f0;
    }

    .lcr-table td:last-child { border-bottom: none; }

    .lcr-table td::before {
        font-weight: 700;
        color: var(--lcr-color-neutral);
        font-size: .65rem;
        text-transform: uppercase;
        letter-spacing: .04em;
        flex: none;
        margin-right: 4px;
    }

    .lcr-table td[data-col="ref"]::before     { content: "Réf. : "; }
    .lcr-table td[data-col="heure"]::before   { content: "Heure : "; }
    .lcr-table td[data-col="nom"]::before     { content: "Nom : "; }
    .lcr-table td[data-col="service"]::before { content: "Service : "; }
    .lcr-table td[data-col="couv"]::before    { content: "Couv. : "; }
    .lcr-table td[data-col="statut"]::before  { content: "Statut : "; }
    .lcr-table td[data-col="source"]::before  { content: "Source : "; }
    .lcr-table td[data-col="saisi"]::before   { content: "Saisi : "; }
    .lcr-table td[data-col="valide"]::before  { content: "Validé : "; }
    .lcr-table td[data-col="tel"]::before     { content: "Tél. : "; }
    .lcr-table td[data-col="email"]::before   { content: "Email : "; }
    .lcr-table td[data-col="places"]::before  { content: "Places : "; }
    .lcr-table td[data-col="lang"]::before    { content: "Langue : "; }
    .lcr-table td[data-col="actions"]::before { display: none; }

    /* Reset les width fixes en mode card */
    .lcr-table th, .lcr-table td { width: auto !important; white-space: normal !important; }

    /* Colonne source et saisi par : masquer sur mobile (accessibles via modal) */
    .lcr-table td[data-col="source"],
    .lcr-table td[data-col="saisi"],
    .lcr-table td[data-col="valide"],
    .lcr-table td[data-col="ref"] {
        display: none;
    }

    /* Actions : ligne compacte de boutons */
    .lcr-table td.lcr-actions {
        display: flex;
        flex-wrap: wrap;
        gap: 4px;
        padding-top: 6px;
        align-items: center;
    }

    .lcr-table td.lcr-actions::before { display: none; }

    .lcr-actions .lcr-btn {
        margin-right: 0;
        flex: 0 0 auto;
        min-width: 0;
        min-height: 36px;
        padding: 6px 10px;
        font-size: .72rem;
        justify-content: center;
        text-align: center;
    }

    /* ── Navigation date ──────────────────────────────────────────────────── */
    .lcr-dashboard__nav {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        gap: 8px;
    }

    .lcr-date-dow {
        order: -1;
        width: 100%;
        font-size: .9rem;
    }

    .lcr-dashboard__nav input[type=date] {
        flex: 1 1 auto;
        max-width: none;
    }

    /* ── Modal → bottom sheet ─────────────────────────────────────────────── */
    .lcr-modal-overlay {
        align-items: flex-end;
        justify-content: stretch;
    }

    .lcr-modal {
        width: 100%;
        max-width: 100%;
        border-radius: var(--lcr-radius) var(--lcr-radius) 0 0;
        padding: 24px 20px;
        max-height: 85vh;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* Modal édition : même bottom sheet, scrollable */
    #lcr-edit-overlay {
        align-items: flex-end;
        justify-content: stretch;
    }

    #lcr-edit-overlay > div,
    #lcr-edit-overlay .lcr-modal {
        width: 100%;
        max-width: 100%;
        border-radius: var(--lcr-radius) var(--lcr-radius) 0 0;
        max-height: 90vh;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* ── Couverts : wrap sur petit écran ──────────────────────────────────── */
    .lcr-covers-selector {
        gap: 6px;
    }

    .lcr-covers-option span {
        width: 42px;
        height: 42px;
    }

    /* ── Synthèse nav ─────────────────────────────────────────────────────── */
    .lcr-synthese {
        padding: 0 16px;
    }

    .lcr-synthese__controls {
        flex-direction: column;
        align-items: stretch;
    }

    .lcr-synthese__nav {
        flex-wrap: wrap;
        justify-content: space-between;
    }

    .lcr-synthese__period-label {
        min-width: unset;
        text-align: center;
        flex: 1;
    }

    .lcr-period-toggle {
        width: 100%;
        justify-content: stretch;
    }

    .lcr-period-btn {
        flex: 1;
        text-align: center;
        min-height: 44px;
    }

    /* ── Table semaine → scroll horizontal ───────────────────────────────── */
    .lcr-synthese > .lcr-syn-table-wrap,
    #lcr-syn-content {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .lcr-syn-table {
        min-width: 520px;
    }

    /* ── Calendrier mois ──────────────────────────────────────────────────── */
    .lcr-syn-cal {
        border-spacing: 3px;
        font-size: .72rem;
    }

    .lcr-syn-cal-cell {
        min-height: 70px;
    }

    .lcr-syn-cal-link {
        padding: 5px 6px;
        gap: 4px;
    }

    .lcr-syn-cal-num {
        font-size: .8rem;
    }

    .lcr-syn-cal-service {
        font-size: .65rem;
        padding: 3px 4px;
    }

    .lcr-syn-toggle-btn {
        min-width: 20px;
        min-height: 20px;
    }

    /* ── Stats rapides ────────────────────────────────────────────────────── */
    .lcr-stat {
        min-width: 80px;
        padding: 10px 12px;
    }

    .lcr-stat__value { font-size: 1.5rem; }
}

/* ── Très petit écran (≤ 400px) ──────────────────────────────────────────── */
@media (max-width: 400px) {

    .lcr-table td::before {
        font-size: .6rem;
    }

    .lcr-covers-option span {
        width: 38px;
        height: 38px;
        font-size: .85rem;
    }

    .lcr-syn-cal-cell { min-height: 44px; }
    .lcr-syn-cal-service { display: none; }
    .lcr-syn-cal-num { font-size: .7rem; }

    .lcr-synthese { padding: 0 10px; }
    .lcr-synthese__stats { gap: 8px; }
    .lcr-stat { min-width: 60px; }
}
/* ═══════════════════════════════════════════════════════════════════════════
   SYNTHÈSE
   ═══════════════════════════════════════════════════════════════════════════ */

.lcr-synthese {
    font-family: var(--lcr-font);
    max-width: 960px;
    margin: 0 auto;
}

/* ── Contrôles ─────────────────────────────────────────────────────────────── */
.lcr-synthese__controls {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
}

.lcr-period-toggle {
    display: flex;
    gap: 4px;
    background: #f0f0ee;
    border-radius: var(--lcr-radius);
    padding: 3px;
}

.lcr-period-btn {
    padding: 6px 16px;
    border: none;
    border-radius: calc(var(--lcr-radius) - 2px);
    background: transparent;
    color: var(--lcr-color-neutral);
    font-size: .875rem;
    font-weight: 600;
    cursor: pointer;
    transition: background .15s, color .15s;
}

.lcr-period-btn--active {
    background: #fff;
    color: var(--lcr-color-primary);
    box-shadow: 0 1px 3px rgba(0,0,0,.12);
}

.lcr-synthese__nav {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
}

.lcr-synthese__period-label {
    display: inline-block;
    font-size: 1.15rem;
    font-weight: 700;
    min-width: 160px;
    text-align: center;
    color: #fff;
    background: #c0392b;
    padding: .3em .8em;
    border-radius: 6px;
    line-height: 1.3;
}

/* ── Onglets Midi / Soir (vue jour) ───────────────────────────────────────── */
#lcr-syn-service-tabs {
    display: flex;
    gap: 0;
    margin-bottom: 20px;
}

.lcr-syn-svc-tab {
    flex: 1;
    padding: 14px 16px;
    font-size: 1rem;
    font-weight: 700;
    border: 2px solid var(--lcr-color-border);
    background: #fafaf8;
    color: #555;
    cursor: pointer;
    transition: background .2s, color .2s, border-color .2s;
}

.lcr-syn-svc-tab:first-child {
    border-radius: 8px 0 0 8px;
    border-right: 1px solid var(--lcr-color-border);
}

.lcr-syn-svc-tab:last-child {
    border-radius: 0 8px 8px 0;
    border-left: 1px solid var(--lcr-color-border);
}

.lcr-syn-svc-tab--active.lcr-syn-svc-tab--midi {
    background: #fff8e1;
    color: #e65100;
    border-color: #ffb300;
}

.lcr-syn-svc-tab--active.lcr-syn-svc-tab--soir {
    background: #e8eaf6;
    color: #283593;
    border-color: #5c6bc0;
}

.lcr-syn-svc-tab:not(.lcr-syn-svc-tab--active):hover {
    background: #f0ede6;
}

/* Mini-jauge dans les onglets service */
.lcr-svc-minibar {
    width: 100%;
    height: 5px;
    background: rgba(0,0,0,.08);
    border-radius: 3px;
    margin-top: 6px;
    overflow: hidden;
}

.lcr-svc-minibar__fill {
    height: 100%;
    border-radius: 3px;
    transition: width .3s;
}

.lcr-svc-minibar__fill--midi {
    background: #e6a817;
}

.lcr-svc-minibar__fill--soir {
    background: #4a5fa0;
}

.lcr-svc-minibar__fill--midi.lcr-svc-minibar--full {
    background: #c0392b;
}

.lcr-svc-minibar__fill--soir.lcr-svc-minibar--full {
    background: #c0392b;
}

.lcr-syn-svc-heading {
    font-size: 1.1rem;
    font-weight: 700;
    margin: 16px 0 8px;
    color: #1a1a1a;
    text-transform: capitalize;
}

@media (max-width: 600px) {
    #lcr-syn-service-tabs {
        margin-bottom: 12px;
    }

    .lcr-syn-svc-tab {
        padding: 10px 8px;
        font-size: .82rem;
        text-align: center;
    }

    .lcr-syn-svc-heading {
        font-size: .95rem;
    }

    .lcr-service-tab {
        padding: 10px 8px;
        font-size: .82rem;
        text-align: center;
    }

    .lcr-dashboard__topbar {
        flex-wrap: wrap;
    }

    .lcr-dashboard__topbar .lcr-btn--outline {
        font-size: .75rem;
        padding: 6px 10px;
        min-height: 36px;
    }

    .lcr-synthese__topnav .lcr-btn--outline {
        font-size: .75rem;
        padding: 6px 10px;
        min-height: 36px;
    }
}

@media (max-width: 400px) {
    .lcr-syn-svc-tab,
    .lcr-service-tab {
        padding: 8px 6px;
        font-size: .75rem;
    }

    .lcr-day-title {
        font-size: 1rem;
        padding: .25em .6em;
    }
}

/* ── Stats rapides ─────────────────────────────────────────────────────────── */
.lcr-synthese__stats {
    display: flex;
    gap: 16px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.lcr-stat {
    flex: 1;
    min-width: 110px;
    background: #fff;
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.lcr-stat__value {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--lcr-color-primary);
    line-height: 1;
}

.lcr-stat__label {
    font-size: .75rem;
    color: var(--lcr-color-neutral);
    text-transform: uppercase;
    letter-spacing: .04em;
}

.lcr-stat--closed {
    border-color: #e53935;
    background: #fff5f5;
    flex: none;
}

.lcr-stat__value--closed {
    color: #e53935;
    font-size: 1.4rem;
    letter-spacing: .08em;
}

.lcr-stat-services {
    display: flex;
    gap: 12px;
    width: 100%;
    margin-top: 8px;
}

.lcr-stat--service {
    flex: 1;
    border-radius: var(--lcr-radius, 8px);
    padding: 12px 16px;
    text-align: center;
}

.lcr-stat--midi {
    background: #fff8eb;
    border: 2px solid #e6a817;
}

.lcr-stat--soir {
    background: #eef0fa;
    border: 2px solid #4a5fa0;
}

.lcr-stat--service .lcr-stat__value {
    font-size: 1.1rem;
}

.lcr-stat--service .lcr-stat__label {
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
}

.lcr-stat--midi .lcr-stat__label { color: #b8900a; font-weight: 800; }
.lcr-stat--soir .lcr-stat__label { color: #4a5fa0; font-weight: 800; }

.lcr-stat-svc--midi { color: #e65100; }
.lcr-stat-svc--soir { color: #283593; }

.lcr-stat--closed-sub .lcr-stat__value {
    color: #ccc;
}

.lcr-stat--closed-sub {
    opacity: .5;
}

@media (max-width: 400px) {
    .lcr-stat-services { flex-direction: column; gap: 8px; }
}

/* ── Table semaine ─────────────────────────────────────────────────────────── */
.lcr-syn-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .875rem;
}

.lcr-syn-table th {
    background: #f5f5f3;
    color: var(--lcr-color-neutral);
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    padding: 8px 10px;
    text-align: left;
}

.lcr-syn-table .lcr-syn-th-service {
    text-align: center;
}

.lcr-syn-table .lcr-syn-th-midi {
    background: #e6a817;
    color: #fff;
}

.lcr-syn-table .lcr-syn-th-soir {
    background: #4a5fa0;
    color: #fff;
    border-left: 3px solid #3a4d88;
}

.lcr-syn-table .lcr-syn-th-total {
    background: #424242;
    color: #fff;
    text-align: center;
    font-size: .78rem;
    font-weight: 700;
    border-left: 3px solid #333;
}

.lcr-syn-td-total {
    text-align: center;
    font-size: .82rem;
    color: #333;
    white-space: nowrap;
    border-left: 3px solid #eee;
}

.lcr-syn-table .lcr-syn-td--midi {
    background: #fff8eb;
}

.lcr-syn-table .lcr-syn-td--soir {
    background: #eef0fa;
    border-left: 3px solid #c0c8e0;
}

.lcr-syn-table .lcr-syn-row--today .lcr-syn-td--midi { background: #ffefcc; }
.lcr-syn-table .lcr-syn-row--today .lcr-syn-td--soir { background: #dde2f4; }

.lcr-syn-table th,
.lcr-syn-table td {
    border: 1px solid #ddd;
}

.lcr-syn-table td {
    padding: 10px;
    color: #222;
    vertical-align: middle;
}

.lcr-syn-table .lcr-syn-td-count {
    background: #e8f5e9;
    text-align: center;
}
.lcr-syn-td-count .lcr-syn-service-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    justify-content: center;
}
.lcr-syn-table .lcr-syn-td-gauge {
    white-space: nowrap;
    background: #e8f5e9;
}
.lcr-syn-td-gauge .lcr-syn-service-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.lcr-syn-table tr:last-child td { border-bottom: none; }

.lcr-syn-table .lcr-syn-row--today td { background: #f0f8f3; }
.lcr-syn-table .lcr-syn-row--today .lcr-syn-td-count,
.lcr-syn-table .lcr-syn-row--today .lcr-syn-td-gauge { background: #d4edda; }
.lcr-syn-table .lcr-syn-row--today .lcr-syn-closed   { background: #f8d7da; }
.lcr-syn-table .lcr-syn-row--today td:first-child {
    font-weight: 700;
    color: var(--lcr-color-primary);
}

/* ── Dates passées : hachures + désactivation des actions ───────────────────── */
.lcr-syn-table .lcr-syn-row--past td,
.lcr-syn-table .lcr-syn-row--past .lcr-syn-td-count,
.lcr-syn-table .lcr-syn-row--past .lcr-syn-td-gauge,
.lcr-syn-table .lcr-syn-row--past .lcr-syn-closed {
    background-image: repeating-linear-gradient(
        -45deg,
        transparent, transparent 4px,
        rgba(0,0,0,.07) 4px, rgba(0,0,0,.07) 6px
    ) !important;
}
.lcr-syn-table .lcr-syn-row--past a,
.lcr-syn-table .lcr-syn-row--past button {
    pointer-events: none;
    cursor: default;
}

.lcr-syn-cal-cell--past,
.lcr-syn-cal .lcr-syn-cal-cell--past {
    background-image: repeating-linear-gradient(
        -45deg,
        transparent, transparent 4px,
        rgba(0,0,0,.07) 4px, rgba(0,0,0,.07) 6px
    ) !important;
}
.lcr-syn-cal-cell--past a,
.lcr-syn-cal-cell--past button {
    pointer-events: none;
    cursor: default;
}

.lcr-syn-closed {
    color: var(--lcr-color-cancel);
    font-style: italic;
    font-size: .8rem;
    text-align: center;
    background: #fde8e8;
}

.lcr-syn-empty { color: #bbb; }

.lcr-syn-day-link {
    color: var(--lcr-color-primary);
    text-decoration: none;
    font-weight: 600;
}
.lcr-syn-day-link:hover { text-decoration: underline; }

/* Mini bar (vue semaine) */
.lcr-syn-mini-bar {
    display: inline-block;
    width: 70px;
    height: 10px;
    background: #fff;
    border-radius: 6px;
    overflow: hidden;
    vertical-align: middle;
    box-shadow: 0 0 0 1px rgba(0,0,0,.12);
}

.lcr-syn-mini-fill {
    height: 100%;
    border-radius: 4px;
    background: var(--lcr-color-primary);
    transition: width .3s;
}
.lcr-syn-mini-fill.lcr-syn-bar--mid  { background: var(--lcr-color-pending); }
.lcr-syn-mini-fill.lcr-syn-bar--full { background: var(--lcr-color-cancel); }

.lcr-syn-covers {
    display: inline-block;
    font-size: .75rem;
    color: var(--lcr-color-neutral);
    margin-left: 6px;
    vertical-align: middle;
}

/* ── Calendrier mois (table) ───────────────────────────────────────────────── */
.lcr-syn-cal {
    width: 100%;
    table-layout: fixed;
    border-collapse: separate;
    border-spacing: 5px;
    font-size: .8rem;
}

.lcr-syn-cal thead th {
    text-align: center;
    font-size: .7rem;
    font-weight: 700;
    color: var(--lcr-color-neutral);
    text-transform: uppercase;
    padding: 4px 0;
    background: none;
    border: none;
}

.lcr-syn-cal td {
    vertical-align: top;
    padding: 0;
    border: none;
    width: calc(100% / 7);
}

/* lcr-syn-cal-cell est sur le <td> lui-même */
.lcr-syn-cal-cell {
    background: #fff;
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    min-height: 90px;
    transition: box-shadow .15s, border-color .15s;
}

.lcr-syn-cal-cell:hover {
    box-shadow: 0 2px 6px rgba(0,0,0,.1);
    border-color: var(--lcr-color-primary);
}

td.lcr-syn-cal-empty { background: transparent !important; border: none !important; pointer-events: none; }

td.lcr-syn-cal-today {
    border-color: var(--lcr-color-primary);
    background: #f0f8f3;
}

td.lcr-syn-cal-today .lcr-syn-cal-num { color: var(--lcr-color-primary); }

td.lcr-syn-cal-empty-day { opacity: .5; }

.lcr-syn-cal-link {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 8px;
    height: 100%;
}

.lcr-syn-cal-num {
    font-size: .9rem;
    font-weight: 700;
    color: #444;
    line-height: 1;
    text-decoration: none;
    display: flex;
    align-items: baseline;
    gap: 2px;
    padding: 2px 0;
}

.lcr-syn-cal-dow {
    font-size: .65rem;
    font-weight: 600;
    color: #999;
    text-transform: uppercase;
}

.lcr-syn-cal-num:hover { color: var(--lcr-color-primary); text-decoration: underline; }

.lcr-syn-cal-bars {
    display: flex;
    flex-direction: column;
    gap: 5px;
    margin-top: 2px;
}

/* Service badges dans la vue mois */
.lcr-syn-cal-service {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: .75rem;
    font-weight: 700;
    padding: 4px 7px;
    border-radius: 6px;
    line-height: 1.3;
    background: #d4edda;
    color: #1b7a3d;
    min-height: 26px;
}

.lcr-syn-cal-service--low  { background: #d4edda; color: #1b7a3d; }
.lcr-syn-cal-service--mid  { background: #fff3e0; color: #e67e00; }
.lcr-syn-cal-service--full { background: #fde8e8; color: #c0392b; }

.lcr-syn-cal-service.lcr-syn-cal-closed {
    background: #f8d7da;
    color: #c0392b;
    font-style: italic;
    font-weight: 700;
}

/* ── Vue semaine mobile : onglets Midi / Soir ───────────────────────────────── */
.lcr-syn-tabs-wrap {
    background: #fff;
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    overflow: hidden;
}

.lcr-syn-tab-btns {
    display: flex;
    border-bottom: 2px solid var(--lcr-color-border);
}

.lcr-syn-tab-btn {
    flex: 1;
    padding: 13px;
    background: #f5f5f3;
    border: none;
    font-size: 1rem;
    font-weight: 700;
    color: var(--lcr-color-neutral);
    cursor: pointer;
    transition: background .15s, color .15s;
}

.lcr-syn-tab-btn--active {
    background: #fff;
    color: var(--lcr-color-primary);
    border-bottom: 2px solid var(--lcr-color-primary);
    margin-bottom: -2px;
}

.lcr-syn-tab-panel--hidden { display: none; }

.lcr-syn-tab-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 13px 14px;
    border-bottom: 1px solid #f0f0f0;
}

.lcr-syn-tab-row:last-child { border-bottom: none; }

.lcr-syn-tab-row__link {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    text-decoration: none;
    color: inherit;
}

.lcr-syn-tab-row__day {
    font-weight: 700;
    font-size: .95rem;
    min-width: 52px;
    color: #333;
}

.lcr-syn-tab-row--today .lcr-syn-tab-row__day { color: var(--lcr-color-primary); }
.lcr-syn-tab-row--past { opacity: .6; }

.lcr-syn-tab-row__badges {
    display: flex;
    gap: 4px;
    align-items: center;
}

.lcr-syn-tab-row__closed {
    flex: 1;
    font-size: .85rem;
    color: var(--lcr-color-cancelled);
    font-style: italic;
}

.lcr-syn-tab-row__hint {
    flex: 1;
    font-size: .82rem;
    color: var(--lcr-color-primary);
    opacity: .65;
    font-style: italic;
}

.lcr-syn-tab-row__covers {
    font-size: .82rem;
    color: var(--lcr-color-neutral);
    white-space: nowrap;
}

.lcr-syn-tab-row .lcr-syn-mini-bar { width: 55px; flex-shrink: 0; }
.lcr-syn-tab-row .lcr-syn-toggle-btn { margin-left: 0; }

/* ── Responsive synthèse (règles complémentaires ≤ 768px) ─────────────────── */
@media (max-width: 768px) {
    .lcr-syn-mini-bar { width: 45px; }
}

/* ── Lien retour inter-pages ───────────────────────────────────────────────── */
.lcr-back-link {
    font-size: .8rem;
    color: #000;
    text-decoration: none;
    font-weight: 600;
    white-space: nowrap;
    transition: color .15s;
}

.lcr-back-link:hover { color: var(--lcr-color-primary); }

.lcr-back-link--right { margin-left: auto; }

.lcr-synthese__topnav {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.lcr-synthese__page-title {
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0;
    color: #1a1a1a;
}

.lcr-btn--pending-link {
    background: #fff3e0;
    color: #111;
    border: 1px solid #ffcc80;
    font-size: .85rem;
    padding: 6px 14px;
}
.lcr-btn--pending-link:hover { background: #ffe0b2; border-color: #ffa726; color: #111; }

.lcr-btn--no-pending {
    background: #e8f5e9;
    color: #2e7d32;
    border: 1px solid #a5d6a7;
    font-size: .85rem;
    padding: 6px 14px;
    border-radius: var(--lcr-radius);
    cursor: default;
    pointer-events: none;
}

/* ── Liste des réservations sous le tableau de synthèse ─────────────────────── */
#lcr-syn-resa-list {
    margin-top: 32px;
}

.lcr-syn-resa-list__day {
    margin-bottom: 28px;
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    overflow: hidden;
}

.lcr-syn-resa-list__day .lcr-table {
    margin: 0;
}

.lcr-syn-resa-list__day--past {
    opacity: .65;
}

.lcr-syn-resa-list__date {
    font-size: .95rem;
    font-weight: 700;
    color: #333;
    margin: 0;
    padding: 10px 14px;
    background: var(--lcr-color-bg);
    border-bottom: 2px solid var(--lcr-color-border);
}

.lcr-syn-resa-list__date a {
    color: inherit;
    text-decoration: none;
}

.lcr-syn-resa-list__date a:hover {
    color: var(--lcr-color-primary);
    text-decoration: underline;
}

.lcr-syn-resa-list__empty {
    color: var(--lcr-color-neutral);
    font-style: italic;
    font-size: .9rem;
    margin-top: 24px;
}

/* ── Liens service synthèse ────────────────────────────────────────────────── */
.lcr-syn-service-link {
    display: block;
    text-decoration: none;
    color: inherit;
    padding: 4px 6px;
    margin: -4px -6px;
    border-radius: var(--lcr-radius);
    transition: background .15s;
}

.lcr-syn-service-link:hover { background: #f0f8f3; }

.lcr-syn-add-hint {
    font-size: .75rem;
    color: var(--lcr-color-primary);
    opacity: .6;
    font-style: italic;
}

.lcr-syn-service-link:hover .lcr-syn-add-hint { opacity: 1; }

/* Service badge = lien en vue mois */
a.lcr-syn-cal-service { text-decoration: none; cursor: pointer; }
a.lcr-syn-cal-service:hover { filter: brightness(.9); }

/* ── Bouton toggle fermeture synthèse ──────────────────────────────────────── */
.lcr-syn-toggle-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    border: 1px solid currentColor;
    border-radius: 4px;
    background: transparent;
    cursor: pointer;
    font-size: .75rem;
    line-height: 1;
    padding: 0;
    margin-left: 4px;
    vertical-align: middle;
    opacity: .55;
    transition: opacity .15s;
    flex-shrink: 0;
}

.lcr-syn-toggle-btn:hover { opacity: 1; }

/* Dans la vue semaine : couleur selon état + alignement à droite */
.lcr-syn-closed .lcr-syn-toggle-btn  { color: var(--lcr-color-confirm); border-color: var(--lcr-color-confirm); float: right; }
.lcr-syn-td-gauge .lcr-syn-toggle-btn { color: var(--lcr-color-neutral); border-color: var(--lcr-color-neutral); float: right; }

/* Dans la vue mois */
.lcr-syn-cal-service-row {
    display: flex;
    align-items: center;
    gap: 2px;
}

.lcr-syn-cal-service-row .lcr-syn-toggle-btn {
    width: 22px;
    height: 22px;
    font-size: .75rem;
}

.lcr-syn-cal-closed .lcr-syn-toggle-btn,
.lcr-syn-cal-service-row .lcr-syn-cal-closed ~ .lcr-syn-toggle-btn { color: var(--lcr-color-confirm); border-color: var(--lcr-color-confirm); }
.lcr-syn-cal-service-row .lcr-syn-cal-service--low ~ .lcr-syn-toggle-btn,
.lcr-syn-cal-service-row .lcr-syn-cal-service--full ~ .lcr-syn-toggle-btn { color: var(--lcr-color-cancel); border-color: var(--lcr-color-cancel); }

/* ── Page réservations en attente ──────────────────────────────────────────── */
.lcr-pending__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
}

.lcr-pending__title {
    margin: 0;
    font-size: 1.4rem;
}

.lcr-pending__count {
    margin: 0 0 16px;
    color: var(--lcr-color-neutral);
    font-size: .95rem;
}

.lcr-pending__count strong {
    font-size: 1.3rem;
    color: var(--lcr-color-pending);
}

.lcr-pending {
    max-width: 100%;
    overflow-x: auto;
}

.lcr-pending .lcr-syn-resa-list__day {
    overflow-x: auto;
}

.lcr-pending .lcr-table {
    width: 100%;
    min-width: 700px;
}

/* ── Modal édition ─────────────────────────────────────────────────────────── */
.lcr-modal--edit {
    max-width: 620px;
    padding: 36px 40px 32px;
}

.lcr-modal--edit .lcr-modal__title {
    font-size: 1.25rem;
    margin-bottom: 24px;
    padding-bottom: 14px;
    border-bottom: 2px solid var(--lcr-color-border);
}

/* Chaque champ dans le modal édition */
.lcr-modal--edit .lcr-field {
    margin-bottom: 0;
}

.lcr-modal--edit .lcr-field label {
    font-size: .8rem;
    font-weight: 700;
    color: var(--lcr-color-neutral);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 4px;
}

.lcr-modal--edit .lcr-field input,
.lcr-modal--edit .lcr-field select,
.lcr-modal--edit .lcr-field textarea {
    padding: 11px 14px;
    font-size: 1rem;
    border-radius: 6px;
    border: 1.5px solid var(--lcr-color-border);
    background: #fafafa;
}

.lcr-modal--edit .lcr-field input:focus,
.lcr-modal--edit .lcr-field select:focus,
.lcr-modal--edit .lcr-field textarea:focus {
    background: #fff;
    border-color: var(--lcr-color-primary);
    box-shadow: 0 0 0 3px rgba(58,111,76,.12);
}

/* Ligne 1 : Nom / Tél / Email → Nom pleine largeur, Tél + Email côte à côte */
.lcr-modal--edit .lcr-field-row {
    gap: 16px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.lcr-modal--edit .lcr-field-row .lcr-field {
    flex: 1 1 220px;
}

/* Ligne 2 : Heure + Couverts côte à côte */
.lcr-modal--edit .lcr-field-row + .lcr-field-row .lcr-field {
    flex: 1 1 150px;
}

/* Remarque pleine largeur */
.lcr-modal--edit > .lcr-field {
    margin-bottom: 20px;
}

/* Bouton enregistrer */
.lcr-modal--edit > .lcr-btn--primary {
    width: 100%;
    justify-content: center;
    padding: 13px;
    font-size: 1rem;
    margin-top: 8px;
}

/* Mobile */
@media (max-width: 600px) {
    .lcr-modal--edit {
        padding: 28px 20px 24px;
    }
    .lcr-modal--edit .lcr-field-row .lcr-field {
        flex: 1 1 100%;
    }
}

/* ── Page Paramètres ───────────────────────────────────────────────────────── */
.lcr-settings__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 24px;
}

.lcr-settings__title {
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0;
    color: #1a1a1a;
}

.lcr-settings__feedback {
    margin-bottom: 16px;
}

.lcr-settings__section {
    background: #fff;
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    padding: 24px 28px;
    margin-bottom: 24px;
}

.lcr-settings__section-title {
    font-size: 1.05rem;
    font-weight: 700;
    margin: 0 0 6px;
    color: #1a1a1a;
}

/* ── Onglets de navigation (Paramètres) ────────────────────────────────────── */
.lcr-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
    margin: 16px 0 20px;
    border-bottom: 2px solid var(--lcr-color-border, #e0d8cc);
    padding: 0;
}

.lcr-tab {
    background: transparent;
    border: none;
    border-bottom: 3px solid transparent;
    padding: 10px 18px;
    font-size: 14px;
    font-weight: 500;
    color: #888;
    cursor: pointer;
    transition: all .2s;
    margin-bottom: -2px;
    border-radius: 6px 6px 0 0;
}

.lcr-tab:hover {
    color: var(--lcr-color-primary, #99211d);
    background: rgba(0, 0, 0, .03);
}

.lcr-tab--active {
    color: var(--lcr-color-primary, #99211d);
    border-bottom-color: var(--lcr-color-primary, #99211d);
    font-weight: 600;
    background: transparent;
}

.lcr-tab-panel {
    display: none;
    animation: lcr-tab-fade .25s ease-out;
}

.lcr-tab-panel--active {
    display: block;
}

@keyframes lcr-tab-fade {
    from { opacity: 0; transform: translateY(4px); }
    to   { opacity: 1; transform: translateY(0); }
}

@media (max-width: 700px) {
    .lcr-tab {
        flex: 1 1 calc(50% - 2px);
        padding: 10px 8px;
        font-size: 13px;
    }
}

/* ── Titres de groupe ─────────────────────────────────────────────────────── */
.lcr-settings__group-title {
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #999;
    margin: 24px 0 8px 4px;
    padding: 0;
}

.lcr-settings__group-title:first-of-type {
    margin-top: 0;
}

/* ── Accordéon ────────────────────────────────────────────────────────────── */
.lcr-accordion {
    background: #fff;
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    margin-bottom: 12px;
    overflow: hidden;
}

.lcr-accordion__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    font-size: .95rem;
    font-weight: 700;
    color: #1a1a1a;
    cursor: pointer;
    user-select: none;
    list-style: none;
    background: #fafaf8;
    border-bottom: 1px solid transparent;
    transition: background .15s;
}

.lcr-accordion__head::-webkit-details-marker { display: none; }

.lcr-accordion__head::after {
    content: '▸';
    font-size: .85rem;
    color: #999;
    transition: transform .2s;
    flex-shrink: 0;
    margin-left: 12px;
}

.lcr-accordion[open] > .lcr-accordion__head {
    border-bottom-color: var(--lcr-color-border);
}

.lcr-accordion[open] > .lcr-accordion__head::after {
    transform: rotate(90deg);
}

.lcr-accordion__body {
    padding: 16px 20px 20px;
}

/* ── Board cards (accordéon imbriqué) ─────────────────────────────────────── */
.lcr-board-card {
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    background: #fafaf8;
    overflow: hidden;
}

.lcr-board-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 14px;
    cursor: pointer;
    user-select: none;
    list-style: none;
    gap: 8px;
}

.lcr-board-card__head::-webkit-details-marker { display: none; }

.lcr-board-card__head::after {
    content: '▸';
    font-size: .75rem;
    color: #bbb;
    transition: transform .2s;
    flex-shrink: 0;
}

.lcr-board-card[open] > .lcr-board-card__head::after {
    transform: rotate(90deg);
}

.lcr-board-card__title {
    font-size: .88rem;
    font-weight: 600;
    color: var(--lcr-color-primary);
}

.lcr-board-card__badge {
    font-size: .7rem;
    color: #888;
    background: #f0f0ee;
    padding: 2px 8px;
    border-radius: 10px;
    white-space: nowrap;
}

.lcr-board-card__body {
    padding: 12px 14px 14px;
    border-top: 1px solid var(--lcr-color-border);
}

.lcr-board-card__actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin: 8px 0;
}

/* ── Bouton small ─────────────────────────────────────────────────────────── */
.lcr-btn--sm {
    padding: 6px 14px;
    font-size: .82rem;
}

.lcr-settings__help {
    font-size: .85rem;
    color: var(--lcr-color-neutral);
    margin: 0 0 20px;
}

.lcr-settings__service-block {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.lcr-settings__service-label {
    font-weight: 700;
    font-size: .9rem;
    min-width: 44px;
    color: var(--lcr-color-primary);
}

.lcr-settings__day-checks {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.lcr-settings__day-label {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 6px 12px;
    border: 1.5px solid var(--lcr-color-border);
    border-radius: 20px;
    cursor: pointer;
    font-size: .85rem;
    font-weight: 600;
    color: #555;
    transition: background .15s, border-color .15s, color .15s;
    user-select: none;
}

.lcr-settings__day-label input[type=checkbox],
.lcr-settings__day-label input[type=radio] {
    display: none;
}

.lcr-settings__day-label--checked {
    background: var(--lcr-color-primary);
    border-color: var(--lcr-color-primary);
    color: #fff;
}

.lcr-settings__row {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.lcr-settings__row-label {
    font-size: .85rem;
    font-weight: 700;
    color: var(--lcr-color-neutral);
    text-transform: uppercase;
    letter-spacing: .04em;
    padding-top: 8px;
    min-width: 70px;
}

.lcr-settings__dates {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    align-items: center;
}

.lcr-settings__date-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .9rem;
    color: #555;
}

.lcr-settings__date-label input[type=date] {
    padding: 8px 12px;
    border: 1.5px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    font-size: .95rem;
}

.lcr-settings__radios {
    display: flex;
    gap: 12px;
    padding-top: 6px;
}

.lcr-settings__radio-label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .9rem;
    color: #333;
    cursor: pointer;
}

.lcr-settings__radio-label input[type=radio] {
    width: 16px;
    height: 16px;
    accent-color: var(--lcr-color-primary);
    cursor: pointer;
}

.lcr-settings__bulk-form > .lcr-btn {
    margin-top: 4px;
}

.lcr-synthese__topnav-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-left: auto;
}

.lcr-synthese__topnav-actions .lcr-btn,
.lcr-synthese__topnav-actions .lcr-col-toggle__btn {
    height: 36px;
    line-height: 36px;
    padding-top: 0;
    padding-bottom: 0;
    font-size: .78rem;
    box-sizing: border-box;
}

.lcr-settings__gauge-row {
    display: flex;
    gap: 24px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.lcr-settings__gauge-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.lcr-settings__gauge-label {
    font-size: .85rem;
    font-weight: 700;
    color: var(--lcr-color-neutral);
    text-transform: uppercase;
    letter-spacing: .04em;
}

.lcr-settings__gauge-unit {
    font-size: .85rem;
    color: #777;
    align-self: center;
}

.lcr-settings__gauge-field .lcr-gauge-edit__row {
    display: flex;
    align-items: center;
    gap: 8px;
}

.lcr-settings__gauge-field input[type=number] {
    width: 90px;
    padding: 8px 10px;
    border: 1.5px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    font-size: 1rem;
    font-weight: 600;
}

/* ── Note de journée ──────────────────────────────────────────────────────── */

.lcr-day-note {
    margin: 0 0 12px;
    border-radius: var(--lcr-radius);
    overflow: hidden;
}

.lcr-day-note__view {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 10px 14px;
    background: #fffde7;
    border: 1.5px solid #f9e04b;
    border-radius: var(--lcr-radius);
    min-height: 40px;
    cursor: default;
}

.lcr-day-note__view--has-note {
    cursor: pointer;
}

.lcr-day-note__icon {
    font-size: 1rem;
    flex-shrink: 0;
    line-height: 1.5;
}

.lcr-day-note__text {
    flex: 1;
    font-size: .92rem;
    line-height: 1.5;
    color: #5d4037;
    white-space: pre-wrap;
}

.lcr-day-note__view:not(.lcr-day-note__view--has-note) .lcr-day-note__text {
    color: #a57e2c;
    font-style: italic;
}

.lcr-day-note__btn {
    background: none;
    border: none;
    cursor: pointer;
    font-size: .95rem;
    color: #a57e2c;
    padding: 0 2px;
    line-height: 1.5;
    flex-shrink: 0;
    opacity: .7;
    transition: opacity .15s;
}

.lcr-day-note__btn:hover { opacity: 1; }

.lcr-day-note__form {
    background: #fffde7;
    border: 1.5px solid #f9e04b;
    border-radius: var(--lcr-radius);
    padding: 10px 14px;
}

.lcr-day-note__form textarea {
    width: 100%;
    box-sizing: border-box;
    border: 1px solid #ddd;
    border-radius: 4px;
    padding: 8px 10px;
    font-size: .92rem;
    resize: vertical;
    font-family: inherit;
    background: #fff;
}

.lcr-day-note__form-actions {
    display: flex;
    gap: 8px;
    margin-top: 8px;
}

/* ── Logo pages internes ──────────────────────────────────────────────────── */

.lcr-page-logo {
    height: 52px;
    width: auto;
    display: block;
    margin-bottom: 16px;
}

/* ── Ardoises (settings) ────────────────────────────────────────────────────── */
.lcr-boards-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: .75rem;
}

.lcr-board-block {
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    padding: 1.25rem;
    background: #fafaf8;
}

.lcr-board-block__title {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--lcr-color-primary);
    margin: 0 0 1rem;
}

.lcr-board-block__preview {
    position: relative;
    margin-bottom: 0.75rem;
}

.lcr-board-block__preview img {
    width: 64px;
    height: 64px;
    object-fit: cover;
    border-radius: 4px;
    display: block;
    cursor: zoom-in;
    border: 1px solid var(--lcr-color-border);
    transition: opacity .15s;
}

.lcr-board-block__preview img:hover {
    opacity: .8;
}

/* ── Lightbox ─────────────────────────────────────────────────────────────── */
.lcr-lightbox {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: rgba(0,0,0,.85);
    align-items: center;
    justify-content: center;
    cursor: zoom-out;
    padding: 20px;
}

.lcr-lightbox--open {
    display: flex;
}

.lcr-lightbox img {
    max-width: 95vw;
    max-height: 90vh;
    object-fit: contain;
    border-radius: 6px;
    box-shadow: 0 4px 40px rgba(0,0,0,.5);
}

.lcr-board-block__date {
    display: block;
    font-size: 0.72rem;
    color: #888;
    margin-top: 0.3rem;
}

.lcr-board-block__upload-label {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    margin-top: 0.5rem;
}

.lcr-board-block__upload-label input[type=file] { display: none; }

.lcr-board-block__upload-label span {
    display: inline-block;
    padding: 0.5rem 1rem;
    background: var(--lcr-color-primary);
    color: #fff;
    border-radius: 4px;
    font-size: 0.82rem;
    font-weight: 500;
    transition: opacity .2s;
}

.lcr-board-block__upload-label:hover span { opacity: .85; }

.lcr-board-block__content {
    margin-top: 1rem;
    padding: 1rem;
    background: #fff;
    border: 1px solid #eee;
    border-radius: 4px;
    font-size: 0.85rem;
    line-height: 1.6;
    color: #1a1a1a;
}

.lcr-board-block__content h5 {
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #888;
    margin: 0 0 0.75rem;
}

.lcr-board-block__content h3 {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--lcr-color-primary);
    margin: 0.75rem 0 0.3rem;
}

.lcr-board-block__content ul {
    margin: 0 0 0.5rem 1rem;
    padding: 0;
}

.lcr-board-block__content li { margin-bottom: 0.2rem; }

.lcr-board-block__content--empty { color: #aaa; font-style: italic; }

.lcr-board-edit {
    width: 100%;
    min-height: 180px;
    padding: 0.75rem;
    font-family: 'Courier New', monospace;
    font-size: 0.8rem;
    line-height: 1.5;
    border: 1px solid #ddd;
    border-radius: 4px;
    resize: vertical;
    background: #fafafa;
    color: #1a1a1a;
    box-sizing: border-box;
}

.lcr-board-block__status {
    margin-top: 0.75rem;
    padding: 0.5rem 0.75rem;
    border-radius: 4px;
    font-size: 0.82rem;
}

.lcr-notice--info {
    background: #e3f2fd;
    color: #1565c0;
    border-left: 3px solid #1565c0;
}

@media (max-width: 700px) {
    .lcr-accordion__head { padding: 12px 16px; font-size: .9rem; }
    .lcr-accordion__body { padding: 12px 16px 16px; }
    .lcr-settings__header { margin-bottom: 16px; }
    .lcr-settings__row { gap: 8px; }
    .lcr-settings__row-label { min-width: 55px; font-size: .8rem; }
    .lcr-settings__day-label { padding: 5px 9px; font-size: .8rem; }
    .lcr-settings__dates { flex-direction: column; gap: 8px; }
}

/* ── Générateur d'affiches ──────────────────────────────────────────────────── */

.lcr-poster-events {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.lcr-poster-card {
    border: 1px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    background: #fafaf8;
    overflow: hidden;
    margin-bottom: 10px;
}

.lcr-poster-card[open] {
    background: #fff;
    box-shadow: 0 2px 12px rgba(0, 0, 0, .06);
}

.lcr-poster-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    gap: 12px;
    cursor: pointer;
    list-style: none;
    user-select: none;
    transition: background .15s;
}

.lcr-poster-card__header::-webkit-details-marker { display: none; }
.lcr-poster-card__header::marker { content: ""; }

.lcr-poster-card__header:hover {
    background: rgba(0, 0, 0, .02);
}

.lcr-poster-card__chevron {
    color: #999;
    font-size: 14px;
    transition: transform .2s;
    margin-left: 4px;
}

.lcr-poster-card[open] .lcr-poster-card__chevron {
    transform: rotate(180deg);
}

.lcr-poster-card__count {
    font-size: .7rem;
    color: var(--lcr-color-primary, #5c4a32);
    background: rgba(184, 92, 53, .12);
    padding: 2px 8px;
    border-radius: 10px;
    margin-top: 4px;
    align-self: flex-start;
    font-weight: 600;
}

.lcr-poster-card__info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.lcr-poster-card__type {
    font-size: .6rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--lcr-color-primary);
}

.lcr-poster-card__title {
    font-size: .9rem;
    color: #1a1a1a;
}

.lcr-poster-card__date {
    font-size: .75rem;
    color: #888;
}

.lcr-poster-card__btns {
    display: flex;
    gap: 6px;
    align-items: center;
    flex-shrink: 0;
}

/* Bouton "À la une" actif (orange) */
.lcr-btn--featured {
    background: #e67e22 !important;
    color: #fff !important;
    border-color: #e67e22 !important;
}

.lcr-btn--featured:hover {
    background: #d35400 !important;
    border-color: #d35400 !important;
}

/* Galerie d'affiches sauvegardées — masonry CSS columns (préserve ratios natifs) */
.lcr-poster-gallery {
    column-count: 4;
    column-gap: 12px;
    padding: 12px 16px 16px;
}

@media (max-width: 1400px) { .lcr-poster-gallery { column-count: 3; } }
@media (max-width: 900px)  { .lcr-poster-gallery { column-count: 2; } }
@media (max-width: 500px)  { .lcr-poster-gallery { column-count: 1; } }

.lcr-poster-thumb {
    position: relative;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--lcr-color-border, #e0d8cc);
    background: #fff;
    transition: transform .2s, box-shadow .2s, border-color .2s;
    display: inline-block;
    width: 100%;
    margin-bottom: 12px;
    break-inside: avoid;
    page-break-inside: avoid;
    -webkit-column-break-inside: avoid;
}

.lcr-poster-thumb:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 14px rgba(0, 0, 0, .12);
}

.lcr-poster-thumb--featured {
    border-color: #e67e22;
    box-shadow: 0 0 0 2px rgba(230, 126, 34, .25);
}

.lcr-poster-thumb__media {
    position: relative;
    display: block;
}

.lcr-poster-thumb__img {
    width: 100%;
    height: auto;
    display: block;
    cursor: zoom-in;
}

.lcr-poster-thumb__badge {
    position: absolute;
    top: 6px;
    right: 6px;
    background: #e67e22;
    color: #fff;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .2);
    pointer-events: none;
}

/* Label discret du format de génération sur la vignette */
.lcr-poster-thumb__format {
    position: absolute;
    bottom: 6px;
    left: 6px;
    background: rgba(0, 0, 0, .65);
    backdrop-filter: blur(4px);
    color: #fff;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .08em;
    padding: 3px 7px;
    border-radius: 4px;
    pointer-events: none;
    text-transform: uppercase;
}

.lcr-poster-thumb__format--insta    { background: rgba(193, 53, 132, .85); }
.lcr-poster-thumb__format--facebook { background: rgba(24, 119, 242, .85); }
.lcr-poster-thumb__format--carre    { background: rgba(91, 46, 161, .85); }
.lcr-poster-thumb__format--affiche  { background: rgba(0, 0, 0, .7); }

.lcr-poster-thumb__actions {
    display: flex;
    gap: 4px;
    padding: 6px;
    flex-wrap: wrap;
    justify-content: center;
    background: #faf8f4;
    border-top: 1px solid var(--lcr-color-border, #e0d8cc);
}

.lcr-poster-thumb__actions .lcr-btn {
    font-size: .68rem !important;
    padding: 3px 6px !important;
    flex: 1 1 auto;
    text-align: center;
}


/* ── Workspace de génération (refonte ergonomique) ─────────────────────────── */
.lcr-poster-card__workspace {
    padding: 14px 16px 16px;
    border-top: 1px solid var(--lcr-color-border);
    background: #fff;
}

/* Section bloc (titre + contenu) */
.lcr-poster-section {
    margin-bottom: 14px;
}

.lcr-poster-section__title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #888;
    margin-bottom: 8px;
}

.lcr-poster-section__title small {
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    color: #aaa;
    margin-left: 4px;
}

/* 3 slots d'images côte-à-côte */
.lcr-poster-card__ref-slots {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}

.lcr-poster-slot {
    display: flex;
    flex-direction: column;
    gap: 6px;
    background: #faf8f4;
    border-radius: 10px;
    padding: 8px;
}

.lcr-poster-slot__head {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 600;
    color: #5c4a32;
}

.lcr-poster-slot__head span {
    font-size: 14px;
}

.lcr-poster-slot__label {
    display: block;
    cursor: pointer;
    margin: 0;
}

.lcr-poster-slot__dropzone {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 72px;
    padding: 8px;
    border: 2px dashed var(--lcr-color-border);
    border-radius: 8px;
    background: #fff;
    text-align: center;
    transition: border-color .2s, background .2s;
}

.lcr-poster-slot__dropzone:hover {
    border-color: var(--lcr-color-primary, #99211d);
    background: rgba(184, 92, 53, .04);
}

.lcr-poster-slot__hint {
    font-size: 11px;
    line-height: 1.4;
    color: #888;
}

.lcr-poster-slot__hint em {
    color: #aaa;
    font-style: normal;
    font-size: 10px;
}

.lcr-poster-slot__pickers {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
}

.lcr-poster-slot__pickers .lcr-btn {
    flex: 1 1 auto;
    font-size: 10.5px !important;
    padding: 4px 6px !important;
    text-align: center;
}

.lcr-poster-slot__preview img {
    border-radius: 6px;
    max-height: 80px;
    width: auto;
}

/* Lignes input compactes (brief, accroche) */
.lcr-poster-input-row {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
}

.lcr-poster-input-row__label {
    font-size: 12px;
    font-weight: 600;
    color: #5c4a32;
    white-space: nowrap;
}

.lcr-poster-input-row textarea,
.lcr-poster-input-row input[type="text"] {
    width: 100%;
    padding: 6px 10px;
    font-size: 13px;
    border: 1px solid var(--lcr-color-border, #d6cdbf);
    border-radius: 6px;
    background: #fff;
}

.lcr-poster-input-row textarea {
    resize: vertical;
    min-height: 32px;
    max-height: 120px;
    font-family: inherit;
}

/* Section "Lancer" : format pills + bouton primaire */
.lcr-poster-section--launch {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    padding: 10px;
    background: #faf8f4;
    border-radius: 10px;
    margin-top: 8px;
}

.lcr-poster-format-pills {
    display: inline-flex;
    background: #fff;
    border: 1px solid var(--lcr-color-border, #d6cdbf);
    border-radius: 999px;
    padding: 3px;
    gap: 2px;
}

.lcr-poster-format-pill {
    cursor: pointer;
    margin: 0;
    position: relative;
}

.lcr-poster-format-pill input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.lcr-poster-format-pill span {
    display: inline-flex;
    align-items: baseline;
    gap: 4px;
    padding: 6px 12px;
    font-size: 12px;
    font-weight: 600;
    color: #888;
    border-radius: 999px;
    transition: all .15s;
    user-select: none;
    white-space: nowrap;
}

.lcr-poster-format-pill span small {
    font-size: 10px;
    font-weight: 400;
    color: #aaa;
}

.lcr-poster-format-pill input:checked + span {
    background: var(--lcr-color-primary, #99211d);
    color: #fff;
}

.lcr-poster-format-pill input:checked + span small {
    color: rgba(255, 255, 255, .8);
}

.lcr-poster-format-pill:hover input:not(:checked) + span {
    color: #5c4a32;
    background: rgba(0, 0, 0, .03);
}

.lcr-poster-launch-actions {
    margin-left: auto;
    display: flex;
    gap: 6px;
    align-items: center;
}

.lcr-poster-section--launch .lcr-poster-launch {
    padding: 10px 22px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
}

.lcr-poster-section--launch .lcr-poster-launch-all {
    padding: 10px 16px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    border: 1px solid var(--lcr-color-primary, #99211d);
    color: var(--lcr-color-primary, #99211d);
}

.lcr-poster-section--launch .lcr-poster-launch-all:hover {
    background: rgba(184, 92, 53, .08);
}

/* Grille de progression "Les 3 formats" */
.lcr-poster-multi {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin-top: 12px;
}

.lcr-poster-multi-item {
    background: #fff;
    border: 1px solid var(--lcr-color-border, #e0d8cc);
    border-radius: 10px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.lcr-poster-multi-item__title {
    padding: 6px 10px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #5c4a32;
    background: #faf8f4;
    border-bottom: 1px solid var(--lcr-color-border, #e0d8cc);
    text-align: center;
}

.lcr-poster-multi-item__body {
    padding: 8px;
    min-height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.lcr-poster-multi-item .lcr-poster-result {
    width: 100%;
}

.lcr-poster-multi-item .lcr-poster-result__img {
    width: 100%;
    height: auto;
    border-radius: 6px;
    margin-bottom: 6px;
}

@media (max-width: 700px) {
    .lcr-poster-multi { grid-template-columns: 1fr; }
    .lcr-poster-launch-actions {
        margin-left: 0;
        width: 100%;
        flex-direction: column;
    }
    .lcr-poster-section--launch .lcr-poster-launch,
    .lcr-poster-section--launch .lcr-poster-launch-all {
        width: 100%;
    }
}

/* Backward compat : les anciennes classes restent neutres */
.lcr-poster-style-toggle { display: none; }

/* Responsive */
@media (max-width: 700px) {
    .lcr-poster-card__ref-slots { grid-template-columns: 1fr; }
    .lcr-poster-input-row {
        grid-template-columns: 1fr;
        gap: 4px;
    }
    .lcr-poster-input-row__label {
        font-size: 11px;
    }
    .lcr-poster-input-row .lcr-btn {
        align-self: flex-end;
    }
    .lcr-poster-section--launch {
        flex-direction: column;
        align-items: stretch;
    }
    .lcr-poster-format-pills {
        justify-content: center;
        align-self: center;
    }
    .lcr-poster-section--launch .lcr-poster-launch {
        margin-left: 0;
        margin-top: 4px;
    }
}

.lcr-poster-card__status {
    margin: 10px 0 8px;
}

/* Résultat généré */
.lcr-poster-result {
    text-align: center;
}

.lcr-poster-result__img {
    max-width: 320px;
    width: 100%;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0,0,0,.12);
    margin-bottom: 12px;
}

.lcr-poster-result__actions {
    display: flex;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
}

@media (max-width: 600px) {
    .lcr-poster-card__header { flex-direction: column; align-items: flex-start; }
    .lcr-poster-result__img { max-width: 100%; }
}

/* ── Formulaire de connexion inline (pages privées) ────────────────────────── */
.lcr-login-inline {
    max-width: 400px;
    margin: 3rem auto;
    padding: 2.5rem 2rem;
    background: #fff;
    border: 1.5px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    text-align: center;
}

.lcr-login-inline__icon {
    color: var(--lcr-color-primary);
    margin-bottom: 1rem;
}

.lcr-login-inline__title {
    font-size: 1.5rem;
    font-weight: 600;
    color: #1c1a17;
    margin: 0 0 0.4rem;
}

.lcr-login-inline__desc {
    font-size: 0.9rem;
    color: #777;
    margin: 0 0 1.5rem;
}

.lcr-login-inline__error {
    background: rgba(184,92,56,0.1);
    border-left: 3px solid #b85c38;
    color: #b85c38;
    font-size: 0.88rem;
    padding: 0.75rem 1rem;
    border-radius: 0 var(--lcr-radius) var(--lcr-radius) 0;
    margin-bottom: 1.25rem;
    text-align: left;
}

.lcr-login-inline__form { text-align: left; }

.lcr-login-inline__label {
    display: block;
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #888;
    margin-bottom: 0.4rem;
}

.lcr-login-inline__input {
    display: block;
    width: 100%;
    padding: 0.75rem 1rem;
    font-size: 0.95rem;
    color: #1c1a17;
    background: #fafaf8;
    border: 1.5px solid var(--lcr-color-border);
    border-radius: var(--lcr-radius);
    outline: none;
    box-sizing: border-box;
    margin-bottom: 1rem;
    transition: border-color .2s, box-shadow .2s;
}

.lcr-login-inline__input:focus {
    border-color: var(--lcr-color-primary);
    box-shadow: 0 0 0 3px rgba(58,90,64,0.12);
}

.lcr-login-inline__options {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0 0 1.5rem;
    gap: 1rem;
}

.lcr-login-inline__remember {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.85rem;
    color: #888;
    cursor: pointer;
}

.lcr-login-inline__remember input[type="checkbox"] {
    accent-color: var(--lcr-color-primary);
    width: 15px;
    height: 15px;
}

.lcr-login-inline__forgot {
    font-size: 0.82rem;
    color: #888;
    text-decoration: none;
    white-space: nowrap;
}

.lcr-login-inline__forgot:hover { color: #b85c38; }

.lcr-login-inline__submit {
    display: block;
    width: 100%;
    padding: 0.85rem 1rem;
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #fff;
    background: #1c1a17;
    border: none;
    border-radius: var(--lcr-radius);
    cursor: pointer;
    transition: background .2s;
}

.lcr-login-inline__submit:hover { background: var(--lcr-color-primary); }

/* ══════════════════════════════════════════════════════════════════════════
   GÉNÉRATEUR D'AFFICHES — Sidebar persistante + presets + galerie
   ══════════════════════════════════════════════════════════════════════════ */

/* Bandeau collapsible "Réglages de génération" (au-dessus des events) */
.lcr-poster-sidebar {
    background: var(--lcr-color-cream, #f8f6f2);
    border: 1px solid var(--lcr-color-border, #e0d8cc);
    border-radius: var(--lcr-radius, 10px);
    margin-bottom: 16px;
    overflow: hidden;
}

.lcr-poster-sidebar__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    cursor: pointer;
    list-style: none;
    user-select: none;
    transition: background .15s;
}

.lcr-poster-sidebar__head::-webkit-details-marker { display: none; }
.lcr-poster-sidebar__head::marker { content: ""; }
.lcr-poster-sidebar__head:hover { background: rgba(0, 0, 0, .03); }

.lcr-poster-sidebar__title {
    margin: 0;
    font-size: 14px;
    font-weight: 600;
    color: var(--lcr-color-primary, #5c4a32);
    letter-spacing: .03em;
    text-transform: uppercase;
}

.lcr-poster-sidebar__toggle {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #fff;
    border: 1px solid var(--lcr-color-border, #d6cdbf);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    line-height: 1;
    color: var(--lcr-color-primary, #5c4a32);
    font-weight: 600;
    transition: transform .2s;
}

.lcr-poster-sidebar:not([open]) .lcr-poster-sidebar__toggle::before { content: '+'; }
.lcr-poster-sidebar[open]      .lcr-poster-sidebar__toggle::before { content: '−'; }

.lcr-poster-sidebar__body {
    padding: 16px;
    border-top: 1px solid var(--lcr-color-border, #e0d8cc);
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px 16px;
    align-items: start;
}

/* Le champ "Presets" et le bouton save prennent toute la largeur */
.lcr-poster-sidebar__body > .lcr-poster-sidebar__field:first-child,
.lcr-poster-sidebar__body > #lcr-ps-save-defaults,
.lcr-poster-sidebar__body > #lcr-ps-save-status {
    grid-column: 1 / -1;
}

.lcr-poster-sidebar__field {
    margin-bottom: 0;
}

.lcr-poster-sidebar__field--toggles {
    grid-column: 1 / -1;
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    padding: 8px 0 4px;
    border-top: 1px dashed var(--lcr-color-border, #d6cdbf);
    margin-top: 4px;
}

.lcr-poster-sidebar__check {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: #5c4a32;
    cursor: pointer;
    user-select: none;
}

.lcr-poster-sidebar__check input[type="checkbox"] {
    margin: 0;
    cursor: pointer;
}

.lcr-poster-sidebar__label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    color: #5c4a32;
    margin-bottom: 4px;
    letter-spacing: .02em;
    text-transform: uppercase;
}

.lcr-poster-sidebar__select {
    width: 100%;
    padding: 6px 8px;
    font-size: 13px;
    border: 1px solid var(--lcr-color-border, #d6cdbf);
    border-radius: 6px;
    background: #fff;
}

.lcr-poster-presets {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.lcr-poster-preset-btn {
    background: #fff;
    border: 1px solid var(--lcr-color-border, #d6cdbf);
    border-radius: 999px;
    padding: 5px 12px;
    font-size: 11px;
    cursor: pointer;
    transition: all .2s;
    color: #5c4a32;
}

.lcr-poster-preset-btn:hover {
    background: var(--lcr-color-primary, #99211d);
    color: #fff;
    border-color: var(--lcr-color-primary, #99211d);
}

.lcr-poster-preset-btn--active {
    background: var(--lcr-color-primary, #99211d);
    color: #fff;
    border-color: var(--lcr-color-primary, #99211d);
    box-shadow: 0 2px 4px rgba(0,0,0,.1);
}

/* Slot inspiration */
.lcr-poster-slot--inspiration .lcr-poster-slot__pickers {
    display: flex;
    gap: 6px;
    justify-content: center;
    margin-top: 6px;
}
.lcr-poster-slot__dropzone--inspiration {
    cursor: default;
    opacity: .85;
}

/* Modale galerie d'inspirations */
.lcr-poster-library {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .65);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 99999;
    padding: 24px;
}

.lcr-poster-library--open { display: flex; }

.lcr-poster-library__panel {
    background: #fff;
    border-radius: 12px;
    width: min(960px, 100%);
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, .3);
}

.lcr-poster-library__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 18px;
    border-bottom: 1px solid #ebe4d6;
    background: #f8f6f2;
}

.lcr-poster-library__head h4 {
    margin: 0;
    font-size: 15px;
    font-weight: 600;
    color: #5c4a32;
}

.lcr-poster-library__close {
    background: transparent;
    border: none;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    color: #5c4a32;
    padding: 0 6px;
}

.lcr-poster-library__close:hover { color: var(--lcr-color-primary, #99211d); }

.lcr-poster-library__grid {
    padding: 18px;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 12px;
    overflow-y: auto;
}

.lcr-poster-library__item {
    cursor: pointer;
    border: 2px solid transparent;
    border-radius: 8px;
    overflow: hidden;
    transition: all .2s;
    background: #fff;
}

.lcr-poster-library__item:hover {
    border-color: var(--lcr-color-primary, #99211d);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, .12);
}

.lcr-poster-library__item img {
    width: 100%;
    aspect-ratio: 2 / 3;
    object-fit: cover;
    display: block;
}

.lcr-poster-library__meta {
    padding: 6px 8px;
    font-size: 11px;
    color: #5c4a32;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

@media (max-width: 1100px) {
    .lcr-poster-library__grid {
        grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    }
}

/* ── Modale Banque d'images CC ─────────────────────────────────────────────── */
.lcr-cclib__panel {
    width: min(1100px, 96vw);
    max-height: 92vh;
}

.lcr-cclib__toolbar {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 12px 18px;
    border-bottom: 1px solid #ebe4d6;
    background: #faf8f4;
    flex-wrap: wrap;
}

.lcr-cclib__sources {
    display: flex;
    gap: 4px;
}

.lcr-cclib__source {
    background: #fff;
    border: 1px solid var(--lcr-color-border, #d6cdbf);
    padding: 6px 14px;
    font-size: 12px;
    cursor: pointer;
    border-radius: 999px;
    color: #5c4a32;
    transition: all .15s;
}

.lcr-cclib__source:hover {
    background: rgba(0, 0, 0, .04);
}

.lcr-cclib__source--active {
    background: var(--lcr-color-primary, #99211d);
    color: #fff;
    border-color: var(--lcr-color-primary, #99211d);
}

.lcr-cclib__search {
    display: flex;
    gap: 6px;
    flex: 1 1 280px;
}

.lcr-cclib__search input {
    flex: 1;
    padding: 6px 10px;
    border: 1px solid var(--lcr-color-border, #d6cdbf);
    border-radius: 6px;
    font-size: 13px;
    background: #fff;
}

.lcr-cclib__close {
    background: transparent;
    border: none;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    color: #5c4a32;
    padding: 0 6px;
}

.lcr-cclib__close:hover { color: var(--lcr-color-primary, #99211d); }

.lcr-cclib__grid {
    flex: 1;
    overflow-y: auto;
    padding: 16px;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 10px;
    background: #fcfaf6;
}

.lcr-cclib__item {
    cursor: pointer;
    border: 2px solid transparent;
    border-radius: 8px;
    overflow: hidden;
    background: #fff;
    transition: all .15s;
    display: flex;
    flex-direction: column;
    position: relative;
}

.lcr-cclib__item:hover {
    border-color: var(--lcr-color-primary, #99211d);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, .12);
}

.lcr-cclib__item--loading {
    opacity: .5;
    pointer-events: none;
}

.lcr-cclib__item img {
    width: 100%;
    aspect-ratio: 3/4;
    object-fit: cover;
    display: block;
}

.lcr-cclib__credit {
    padding: 6px 8px;
    font-size: 11px;
    color: #5c4a32;
    text-align: center;
    background: #faf8f4;
    line-height: 1.3;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.lcr-cclib__credit small {
    display: block;
    font-size: 9px;
    color: #999;
    margin-top: 1px;
}

.lcr-cclib__footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 18px;
    border-top: 1px solid #ebe4d6;
    background: #faf8f4;
    gap: 12px;
}

.lcr-cclib__pageinfo {
    font-size: 12px;
    color: #888;
}

/* ── Modale 5 accroches IA ─────────────────────────────────────────────────── */
.lcr-taglines__panel {
    width: min(560px, 96vw);
}

.lcr-taglines__list {
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow-y: auto;
}

.lcr-taglines__item {
    background: #fff;
    border: 1px solid var(--lcr-color-border, #d6cdbf);
    border-radius: 8px;
    padding: 12px 16px;
    font-size: 14px;
    text-align: left;
    cursor: pointer;
    color: #333;
    line-height: 1.4;
    transition: all .15s;
}

.lcr-taglines__item:hover {
    border-color: var(--lcr-color-primary, #99211d);
    background: #fcfaf6;
    transform: translateX(2px);
}

.lcr-taglines__close {
    background: transparent;
    border: none;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    color: #5c4a32;
    padding: 0 6px;
}
.lcr-taglines__close:hover { color: var(--lcr-color-primary, #99211d); }
