/* Planning Électricien — page d'administration / saisie du planning.
   Thème clair, professionnel. Bleu « entreprise » + ambre « énergie ». */

/* Variables sur :root pour qu'elles s'appliquent AUSSI aux éléments ajoutés
   directement dans <body> (panneau de formulaire, overlay, toast). */
:root {
	--ecpa-bg:        #f4f6fb;
	--ecpa-surface:   #ffffff;
	--ecpa-surface-2: #f0f3f9;
	--ecpa-line:      #dfe4ee;
	--ecpa-line-2:    #eef1f7;
	--ecpa-ink:       #1a2433;
	--ecpa-muted:     #6b7589;
	--ecpa-brand:     #0b63d6;
	--ecpa-brand-d:   #0a2a52;
	--ecpa-accent:    #ffb300;
	--ecpa-afaire:    #f08c00;
	--ecpa-encours:   #1c7ed6;
	--ecpa-termine:   #2f9e44;
	--ecpa-danger:    #e03131;
	--ecpa-radius:    12px;
	--ecpa-shadow:    0 1px 2px rgba(16,30,54,.06), 0 8px 24px rgba(16,30,54,.06);
}

.ecpa-app {
	background: var(--ecpa-bg);
	color: var(--ecpa-ink);
	border-radius: 16px;
	padding: 0;
	overflow: hidden;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	-webkit-font-smoothing: antialiased;
	max-width: 1280px;
	margin: 0 auto;
	border: 1px solid var(--ecpa-line);
}
.ecpa-app *, .ecpa-app *::before, .ecpa-app *::after { box-sizing: border-box; }
/* Le panneau/overlay/toast sont hors de .ecpa-app : on leur applique aussi box-sizing + la police. */
.ecpa-overlay, .ecpa-overlay *, .ecpa-toast {
	box-sizing: border-box;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}
.ecpa-loading { padding: 60px; text-align: center; color: var(--ecpa-muted); }
.ecpa-login { max-width: 420px; margin: 40px auto; padding: 24px; }

/* ---------- En-tête ---------- */
.ecpa-header {
	background: linear-gradient(120deg, var(--ecpa-brand-d), var(--ecpa-brand));
	color: #fff; padding: 18px 22px; display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.ecpa-brand { display: flex; align-items: center; gap: 12px; }
.ecpa-logo {
	width: 42px; height: 42px; border-radius: 11px; display: grid; place-items: center;
	background: var(--ecpa-accent); color: var(--ecpa-brand-d); font-size: 24px; flex: 0 0 auto;
	box-shadow: 0 2px 10px rgba(255,179,0,.4);
}
.ecpa-brand h1 { margin: 0; font-size: 19px; font-weight: 800; letter-spacing: .01em; line-height: 1.1; }
.ecpa-brand p { margin: 2px 0 0; font-size: 12.5px; opacity: .8; font-weight: 500; }
.ecpa-header-meta { margin-left: auto; text-align: right; font-size: 12.5px; opacity: .9; }
.ecpa-header-meta b { display: block; font-size: 14px; font-weight: 700; opacity: 1; }

/* ---------- Onglets de vue ---------- */
.ecpa-nav { display: flex; gap: 4px; background: var(--ecpa-surface); padding: 8px 22px 0; border-bottom: 1px solid var(--ecpa-line); flex-wrap: wrap; }
.ecpa-navbtn {
	border: 0; background: transparent; color: var(--ecpa-muted); cursor: pointer;
	font-size: 14px; font-weight: 700; padding: 12px 16px; border-radius: 8px 8px 0 0;
	border-bottom: 3px solid transparent; min-height: 44px;
}
.ecpa-navbtn:hover { color: var(--ecpa-ink); background: var(--ecpa-surface-2); }
.ecpa-navbtn.is-active { color: var(--ecpa-brand); border-bottom-color: var(--ecpa-brand); }

/* ---------- Zone de contenu ---------- */
.ecpa-body { padding: 20px 22px 26px; }

/* ---------- Barre d'actions ---------- */
.ecpa-actionbar { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.ecpa-weeknav { display: flex; align-items: center; gap: 6px; }
.ecpa-weeknav h2 { margin: 0; font-size: 16px; min-width: 230px; text-align: center; text-transform: capitalize; }
.ecpa-spacer { margin-left: auto; }

/* ---------- Boutons ---------- */
.ecpa-btn {
	border: 1px solid var(--ecpa-line); border-radius: 9px; padding: 10px 16px; font-size: 14px; font-weight: 700;
	cursor: pointer; min-height: 44px; background: var(--ecpa-surface); color: var(--ecpa-ink);
	display: inline-flex; align-items: center; gap: 7px; transition: background .12s, border-color .12s;
}
.ecpa-btn:hover { background: var(--ecpa-surface-2); }
.ecpa-btn-primary { background: var(--ecpa-brand); border-color: var(--ecpa-brand); color: #fff; }
.ecpa-btn-primary:hover { background: #0954b8; }
.ecpa-btn-accent { background: var(--ecpa-accent); border-color: var(--ecpa-accent); color: var(--ecpa-brand-d); }
.ecpa-btn-accent:hover { filter: brightness(.96); }
.ecpa-btn-danger { color: var(--ecpa-danger); border-color: #f5c2c2; background: #fff5f5; }
.ecpa-btn-danger:hover { background: #ffe9e9; }
.ecpa-btn-icon { padding: 10px 13px; }
.ecpa-btn:active { transform: translateY(1px); }
.ecpa-btn:disabled { opacity: .55; cursor: not-allowed; }
.ecpa-btn-sm { padding: 7px 11px; font-size: 13px; min-height: 36px; }

/* ---------- Champs ---------- */
.ecpa-app input, .ecpa-app select, .ecpa-app textarea {
	background: var(--ecpa-surface); color: var(--ecpa-ink);
	border: 1px solid var(--ecpa-line); border-radius: 9px;
	padding: 10px 12px; font-size: 14.5px; min-height: 44px; width: 100%; font-family: inherit;
}
.ecpa-app input:focus, .ecpa-app select:focus, .ecpa-app textarea:focus {
	outline: 0; border-color: var(--ecpa-brand); box-shadow: 0 0 0 3px rgba(11,99,214,.13);
}
.ecpa-app textarea { min-height: 84px; resize: vertical; }
.ecpa-app select { cursor: pointer; }

/* ---------- Badges de statut ---------- */
.ecpa-badge { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; font-weight: 800;
	text-transform: uppercase; letter-spacing: .03em; padding: 4px 9px; border-radius: 999px; white-space: nowrap; }
.ecpa-badge::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.ecpa-st-a_faire  { color: var(--ecpa-afaire);  background: rgba(240,140,0,.12); }
.ecpa-st-en_cours { color: var(--ecpa-encours); background: rgba(28,126,214,.12); }
.ecpa-st-termine  { color: var(--ecpa-termine); background: rgba(47,158,68,.12); }

/* ---------- Planning hebdomadaire (électriciens × jours) ---------- */
.ecpa-grid-wrap { overflow-x: auto; border: 1px solid var(--ecpa-line); border-radius: var(--ecpa-radius); background: var(--ecpa-surface); box-shadow: var(--ecpa-shadow); }
.ecpa-grid { width: 100%; border-collapse: collapse; min-width: 880px; }
.ecpa-grid th, .ecpa-grid td { border: 1px solid var(--ecpa-line-2); vertical-align: top; }
.ecpa-grid thead th {
	background: var(--ecpa-surface-2); padding: 10px 8px; font-size: 12.5px; font-weight: 800;
	color: var(--ecpa-muted); text-transform: uppercase; letter-spacing: .03em; position: sticky; top: 0;
}
.ecpa-grid thead th .d-num { display: block; font-size: 17px; color: var(--ecpa-ink); margin-top: 2px; }
.ecpa-grid thead th.is-today { color: var(--ecpa-brand); }
.ecpa-grid thead th.is-today .d-num { color: var(--ecpa-brand); }
.ecpa-col-person { width: 150px; text-align: left; position: sticky; left: 0; z-index: 2; }
.ecpa-cell-person {
	background: var(--ecpa-surface-2); padding: 12px 10px; font-weight: 700; font-size: 14px;
	position: sticky; left: 0; z-index: 1; width: 150px;
}
.ecpa-cell-person .role { display: block; font-size: 11.5px; color: var(--ecpa-muted); font-weight: 600; margin-top: 2px; }
.ecpa-cell-person .av {
	display: inline-grid; place-items: center; width: 28px; height: 28px; border-radius: 50%;
	background: var(--ecpa-brand); color: #fff; font-size: 12px; font-weight: 800; margin-right: 7px; vertical-align: middle;
}
.ecpa-cell-day { padding: 6px; min-width: 116px; background: var(--ecpa-surface); }
.ecpa-cell-day.is-weekend { background: #fafbfd; }
.ecpa-cell-day.is-today { background: rgba(11,99,214,.04); }
.ecpa-add-mini {
	display: block; width: 100%; border: 1px dashed var(--ecpa-line); background: transparent; color: var(--ecpa-muted);
	border-radius: 8px; padding: 6px; cursor: pointer; font-size: 16px; font-weight: 700; line-height: 1; opacity: 0; transition: opacity .12s;
}
.ecpa-cell-day:hover .ecpa-add-mini { opacity: 1; }
.ecpa-add-mini:hover { border-color: var(--ecpa-brand); color: var(--ecpa-brand); background: rgba(11,99,214,.05); }

/* Mini-carte chantier dans la grille */
.ecpa-mini {
	background: var(--ecpa-surface); border: 1px solid var(--ecpa-line); border-left: 3px solid var(--ecpa-line);
	border-radius: 8px; padding: 7px 8px; margin-bottom: 6px; cursor: pointer; box-shadow: 0 1px 2px rgba(16,30,54,.05);
}
.ecpa-mini:hover { border-color: var(--ecpa-brand); }
.ecpa-mini[data-statut="a_faire"]  { border-left-color: var(--ecpa-afaire); }
.ecpa-mini[data-statut="en_cours"] { border-left-color: var(--ecpa-encours); }
.ecpa-mini[data-statut="termine"]  { border-left-color: var(--ecpa-termine); }
.ecpa-mini .t { font-size: 13px; font-weight: 700; line-height: 1.2; }
.ecpa-mini .s { font-size: 11.5px; color: var(--ecpa-muted); margin-top: 3px; display: flex; gap: 6px; flex-wrap: wrap; }

/* --- Vues Jour / Liste par statut --- */
.ecpa-rows { display: block; }
.ecpa-row { margin-bottom: 8px; padding: 12px 14px; }
.ecpa-row-head { display: flex; justify-content: space-between; gap: 10px; align-items: flex-start; }
.ecpa-section-title2 { font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; color: var(--ecpa-muted); margin: 18px 0 10px; }
.ecpa-section-title2:first-child { margin-top: 4px; }

/* --- Calendrier mensuel --- */
.ecpa-cal-wrap { background: var(--ecpa-surface); border: 1px solid var(--ecpa-line); border-radius: var(--ecpa-radius); padding: 10px; box-shadow: var(--ecpa-shadow); }
.ecpa-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 5px; }
.ecpa-cal-dow { text-align: center; font-size: 11px; font-weight: 800; color: var(--ecpa-muted); text-transform: uppercase; padding: 4px 0; }
.ecpa-cal-cell { background: var(--ecpa-surface-2); border: 1px solid var(--ecpa-line-2); border-radius: 8px; min-height: 92px; padding: 5px; cursor: pointer; }
.ecpa-cal-cell:hover { border-color: var(--ecpa-brand); }
.ecpa-cal-cell.is-out { opacity: .45; }
.ecpa-cal-cell.is-today { border-color: var(--ecpa-brand); box-shadow: inset 0 0 0 1px var(--ecpa-brand); }
.ecpa-cal-num { font-size: 12px; font-weight: 800; color: var(--ecpa-ink); margin-bottom: 3px; }
.ecpa-cal-ev { font-size: 11px; font-weight: 700; border-radius: 5px; padding: 3px 6px; margin-top: 3px; cursor: pointer;
	overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ecpa-cal-ev[data-statut="a_faire"]  { background: rgba(240,140,0,.16);  color: #b35e00; }
.ecpa-cal-ev[data-statut="en_cours"] { background: rgba(28,126,214,.16);  color: #155fa0; }
.ecpa-cal-ev[data-statut="termine"]  { background: rgba(47,158,68,.16);   color: #237a35; }
@media (max-width: 820px) {
	.ecpa-cal-cell { min-height: 60px; padding: 3px; }
	.ecpa-cal-ev { font-size: 10px; padding: 2px 4px; }
	.ecpa-cal-grid { gap: 3px; }
}

/* Bandeau « non planifiés » */
.ecpa-unscheduled { margin-top: 16px; background: #fff9ec; border: 1px solid #ffe3a3; border-radius: var(--ecpa-radius); padding: 12px 14px; }
.ecpa-unscheduled h3 { margin: 0 0 10px; font-size: 13px; text-transform: uppercase; letter-spacing: .03em; color: #a06a00; }
.ecpa-unscheduled .row { display: flex; flex-wrap: wrap; gap: 8px; }
.ecpa-pill {
	background: #fff; border: 1px solid #ffe3a3; border-radius: 999px; padding: 6px 12px; cursor: pointer;
	font-size: 13px; font-weight: 600; display: inline-flex; align-items: center; gap: 7px;
}
.ecpa-pill:hover { border-color: var(--ecpa-accent); }

/* ---------- Tableau de gestion ---------- */
.ecpa-table-wrap { overflow-x: auto; border: 1px solid var(--ecpa-line); border-radius: var(--ecpa-radius); background: var(--ecpa-surface); box-shadow: var(--ecpa-shadow); }
.ecpa-table { width: 100%; border-collapse: collapse; min-width: 760px; }
.ecpa-table th { text-align: left; font-size: 12px; text-transform: uppercase; letter-spacing: .03em; color: var(--ecpa-muted);
	padding: 12px 14px; background: var(--ecpa-surface-2); border-bottom: 1px solid var(--ecpa-line); font-weight: 800; }
.ecpa-table td { padding: 12px 14px; border-bottom: 1px solid var(--ecpa-line-2); font-size: 14px; vertical-align: middle; }
.ecpa-table tbody tr:hover { background: var(--ecpa-surface-2); }
.ecpa-table .t-title { font-weight: 700; }
.ecpa-table .t-sub { color: var(--ecpa-muted); font-size: 12.5px; margin-top: 2px; }
.ecpa-table .t-actions { display: flex; gap: 6px; justify-content: flex-end; }
.ecpa-search { max-width: 260px; }

/* Avatars / chips */
.ecpa-chips { display: flex; gap: 4px; flex-wrap: wrap; }
.ecpa-chip { font-size: 11.5px; font-weight: 700; background: var(--ecpa-surface-2); color: var(--ecpa-ink);
	border: 1px solid var(--ecpa-line); padding: 3px 9px; border-radius: 999px; }
.ecpa-empty { padding: 40px; text-align: center; color: var(--ecpa-muted); }

/* ---------- Formulaire (panneau latéral) ---------- */
.ecpa-overlay { position: fixed; inset: 0; background: rgba(16,30,54,.45); display: flex; justify-content: flex-end; z-index: 99999; }
.ecpa-panel { background: var(--ecpa-surface); width: 100%; max-width: 460px; height: 100%; overflow-y: auto;
	box-shadow: -12px 0 40px rgba(16,30,54,.18); animation: ecpaSlide .18s ease; }
@keyframes ecpaSlide { from { transform: translateX(30px); opacity: .6; } to { transform: none; opacity: 1; } }
.ecpa-panel-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px;
	border-bottom: 1px solid var(--ecpa-line); position: sticky; top: 0; background: var(--ecpa-surface); z-index: 1; }
.ecpa-panel-head h2 { margin: 0; font-size: 18px; }
.ecpa-x { border: 0; background: transparent; font-size: 24px; cursor: pointer; color: var(--ecpa-muted); line-height: 1; width: 36px; height: 36px; border-radius: 8px; }
.ecpa-x:hover { background: var(--ecpa-surface-2); color: var(--ecpa-ink); }
.ecpa-panel-body { padding: 18px 22px 26px; }
.ecpa-field { margin-bottom: 15px; }
.ecpa-field > label { display: block; font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .03em; color: var(--ecpa-muted); margin-bottom: 6px; }
.ecpa-field .hint { font-size: 12px; color: var(--ecpa-muted); margin-top: 5px; }
.ecpa-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

/* Commentaire de fin (lecture seule) */
.ecpa-commentfin { background: var(--ecpa-surface-2); border: 1px solid var(--ecpa-line); border-left: 3px solid var(--ecpa-termine);
	border-radius: 8px; padding: 10px 12px; font-size: 14px; white-space: pre-wrap; }

/* Galerie photos (panneau gestionnaire) */
.ecpa-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.ecpa-gallery .ph { display: block; }
.ecpa-gallery img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 8px; display: block; border: 1px solid var(--ecpa-line); }

/* Champs du panneau (hors de .ecpa-app, donc styles redéfinis ici). */
.ecpa-panel input, .ecpa-panel select, .ecpa-panel textarea {
	background: var(--ecpa-surface); color: var(--ecpa-ink);
	border: 1px solid var(--ecpa-line); border-radius: 9px;
	padding: 10px 12px; font-size: 14.5px; min-height: 44px; width: 100%; font-family: inherit;
}
.ecpa-panel textarea { min-height: 84px; resize: vertical; }
.ecpa-panel input:focus, .ecpa-panel select:focus, .ecpa-panel textarea:focus {
	outline: 0; border-color: var(--ecpa-brand); box-shadow: 0 0 0 3px rgba(11,99,214,.13);
}

/* Sélection des personnes (cases à cocher) */
.ecpa-people { display: flex; flex-wrap: wrap; gap: 7px; }
.ecpa-person-pick {
	display: inline-flex; align-items: center; gap: 7px; border: 1px solid var(--ecpa-line); background: var(--ecpa-surface);
	border-radius: 999px; padding: 7px 13px; cursor: pointer; font-size: 13.5px; font-weight: 600; user-select: none;
}
.ecpa-person-pick input { display: none; }
.ecpa-person-pick.is-on { background: rgba(11,99,214,.1); border-color: var(--ecpa-brand); color: var(--ecpa-brand); }

/* Sélecteur de statut segmenté */
.ecpa-segments { display: flex; gap: 6px; }
.ecpa-segments button { flex: 1; border: 1px solid var(--ecpa-line); background: var(--ecpa-surface); border-radius: 9px;
	padding: 10px; font-weight: 700; font-size: 13.5px; cursor: pointer; min-height: 44px; }
.ecpa-segments button.is-on[data-s="a_faire"]  { background: var(--ecpa-afaire);  border-color: var(--ecpa-afaire);  color: #fff; }
.ecpa-segments button.is-on[data-s="en_cours"] { background: var(--ecpa-encours); border-color: var(--ecpa-encours); color: #fff; }
.ecpa-segments button.is-on[data-s="termine"]  { background: var(--ecpa-termine); border-color: var(--ecpa-termine); color: #fff; }

.ecpa-panel-actions { display: flex; gap: 10px; margin-top: 22px; }
.ecpa-panel-actions .ecpa-btn { flex: 1; justify-content: center; }

/* Toast */
.ecpa-toast { position: fixed; bottom: 22px; left: 50%; transform: translateX(-50%); background: var(--ecpa-ink);
	color: #fff; padding: 12px 20px; border-radius: 10px; font-weight: 600; font-size: 14px; z-index: 100000;
	box-shadow: 0 10px 30px rgba(16,30,54,.3); animation: ecpaSlide .18s ease; }
.ecpa-toast.is-error { background: var(--ecpa-danger); }

/* ---------- Mode plein écran (gabarit dédié /planning) ---------- */
body.ecpa-fullscreen {
	margin: 0 !important;
	padding: 0 !important;
	background: #eef1f7;
	min-height: 100vh;
}
body.ecpa-fullscreen .ecpa-app {
	max-width: none;
	margin: 0;
	border: 0;
	border-radius: 0;
	min-height: 100vh;
}
body.ecpa-fullscreen .ecpa-body {
	max-width: 1500px;
	margin: 0 auto;
	width: 100%;
	padding: 22px 26px 36px;
}
body.ecpa-fullscreen .ecpa-header,
body.ecpa-fullscreen .ecpa-nav { padding-left: 26px; padding-right: 26px; }
body.ecpa-fullscreen .ecpa-login-wrap { min-height: 100vh; }
/* Le mode plein écran neutralise d'éventuels conteneurs résiduels du thème. */
body.ecpa-fullscreen #page, body.ecpa-fullscreen .site, body.ecpa-fullscreen .wp-site-blocks { max-width: none; margin: 0; padding: 0; }

/* Vue équipe (app mobile [planning_electricien]) : fond sombre plein écran. */
body.ecpa-fullscreen-dark { background: #0f1115; }
body.ecpa-fullscreen-dark .ecp-app { max-width: 1100px; margin: 0 auto; border-radius: 0; min-height: 100vh; }
body.ecpa-fullscreen-dark .ecp-login { max-width: 420px; margin: 0 auto; padding: 40px 18px; color: #f2f4f8; }

/* ---------- Bouton déconnexion (en-tête) ---------- */
.ecpa-logout {
	color: #fff; text-decoration: none; font-size: 13px; font-weight: 700; opacity: .85;
	border: 1px solid rgba(255,255,255,.35); border-radius: 8px; padding: 8px 12px; white-space: nowrap;
	background: transparent; cursor: pointer; min-height: 38px;
}
.ecpa-logout:hover { opacity: 1; background: rgba(255,255,255,.12); }

/* ---------- Panneau réglages ---------- */
.ecpa-section-set {
	font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; color: var(--ecpa-muted);
	margin: 22px 0 10px; padding-top: 16px; border-top: 1px solid var(--ecpa-line);
}
.ecpa-warn { background: #fff5f5; border: 1px solid #f5c2c2; color: #c0392b; border-radius: 9px; padding: 10px 12px; font-size: 13px; margin-bottom: 10px; }
.ecpa-set-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--ecpa-line-2); }
.ecpa-set-name { font-weight: 700; font-size: 14px; }
.ecpa-set-state { font-size: 12.5px; font-weight: 700; white-space: nowrap; }
.ecpa-set-state.is-ok { color: var(--ecpa-termine); }
.ecpa-set-state.is-no { color: var(--ecpa-danger); }
.ecpa-check { display: flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 600; cursor: pointer; margin: 4px 0; }
.ecpa-check input { width: 18px; height: 18px; min-height: 0; flex: 0 0 auto; }

/* ---------- Écran de connexion personnalisé ---------- */
.ecpa-login-wrap {
	/* variables redéfinies ici car le bloc est hors de .ecpa-app */
	--ecpa-surface: #ffffff; --ecpa-surface-2: #f0f3f9; --ecpa-line: #dfe4ee; --ecpa-ink: #1a2433;
	--ecpa-brand: #0b63d6; --ecpa-brand-d: #0a2a52; --ecpa-accent: #ffb300;
	min-height: 72vh; display: flex; align-items: center; justify-content: center; padding: 36px 16px;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	background: linear-gradient(160deg, #f4f6fb, #e7edf7);
}
.ecpa-login-card {
	width: 100%; max-width: 380px; background: #fff; border: 1px solid #dfe4ee; border-radius: 18px;
	padding: 34px 28px 30px; box-shadow: 0 16px 50px rgba(16,30,54,.14); text-align: center;
}
.ecpa-login-logo {
	width: 60px; height: 60px; border-radius: 16px; display: grid; place-items: center; margin: 0 auto 14px;
	background: #ffb300; color: #0a2a52; font-size: 32px; box-shadow: 0 6px 18px rgba(255,179,0,.4);
}
.ecpa-login-card h1 { margin: 0; font-size: 21px; font-weight: 800; color: #1a2433; }
.ecpa-login-sub { margin: 4px 0 22px; font-size: 13.5px; color: #6b7589; font-weight: 500; }
.ecpa-login-card label {
	display: block; text-align: left; font-size: 12px; font-weight: 800; text-transform: uppercase;
	letter-spacing: .03em; color: #6b7589; margin: 14px 0 6px;
}
.ecpa-login-card input {
	width: 100%; background: #f7f9fc; color: #1a2433; border: 1px solid #dfe4ee; border-radius: 10px;
	padding: 12px 14px; font-size: 15px; min-height: 48px; box-sizing: border-box; font-family: inherit;
}
.ecpa-login-card input:focus { outline: 0; border-color: #0b63d6; box-shadow: 0 0 0 3px rgba(11,99,214,.14); background: #fff; }
.ecpa-login-submit { width: 100%; margin-top: 22px; justify-content: center; min-height: 50px; font-size: 15px; }
.ecpa-login-err {
	background: #fff5f5; border: 1px solid #f5c2c2; color: #c0392b; border-radius: 10px;
	padding: 10px 12px; font-size: 13.5px; font-weight: 600; margin-bottom: 6px;
}

/* Défilement tactile fluide pour les zones larges. */
.ecpa-grid-wrap, .ecpa-table-wrap { -webkit-overflow-scrolling: touch; }

/* ---------- Responsive : tablette ---------- */
@media (max-width: 1024px) {
	body.ecpa-fullscreen .ecpa-body { padding: 16px 16px 28px; }
	body.ecpa-fullscreen .ecpa-header,
	body.ecpa-fullscreen .ecpa-nav { padding-left: 16px; padding-right: 16px; }
	.ecpa-grid { min-width: 720px; }
	.ecpa-cell-day { min-width: 92px; }
	.ecpa-col-person, .ecpa-cell-person { width: 118px; }
	.ecpa-brand h1 { font-size: 17px; }
	.ecpa-panel { max-width: 420px; }
}

/* ---------- Responsive : téléphone ---------- */
@media (max-width: 820px) {
	.ecpa-header-meta { margin-left: 0; text-align: left; width: 100%; }
	.ecpa-spacer { margin-left: 0; width: 100%; }
	.ecpa-weeknav h2 { min-width: 0; flex: 1; font-size: 15px; }
	.ecpa-grid-2 { grid-template-columns: 1fr; }
	.ecpa-panel { max-width: 100%; }
	.ecpa-navbtn { padding: 12px 10px; font-size: 13px; }
	.ecpa-actionbar { gap: 8px; }
	.ecpa-search { max-width: 100%; flex: 1; }
	.ecpa-logout { padding: 7px 10px; font-size: 12px; }
	.ecpa-col-person, .ecpa-cell-person { width: 104px; }
	.ecpa-cell-person { font-size: 13px; }
	.ecpa-cell-day { min-width: 84px; }
}
