/* Cockpit Heures v2 — CSS scopée sous .heures-mod (généré depuis la maquette validée). */
.heures-mod {--bg:#0E1320; --panel:#151B29; --card:#1A2233; --card2:#20293C;
    --text:#EAEEF6; --dim:#9AA3B5; --muted:#636E83; --border:#283143;
    --navy:#2E4D8E; --red:#E2483D;
    --s-attendu:#8B95AC; --s-retard:#F0564B; --s-recu:#4D8DF0; --s-saisir:#F2A33C; --s-ok:#34C77B; --s-ext:#A06CD5;}
.heures-mod * {box-sizing:border-box}
.heures-mod, .heures-mod {margin:0;background:var(--bg);color:var(--text);
    font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}
.heures-mod {max-width:1560px;margin:0 auto;padding:0 18px 60px}
.heures-mod .hchrome {position:sticky;top:0;z-index:30;background:rgba(14,19,32,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);margin:0 -18px 14px;padding:0 18px}
.heures-mod .hrow1 {display:flex;align-items:center;gap:16px;padding:9px 2px 8px}
.heures-mod .brand {display:flex;align-items:center;gap:10px}
.heures-mod .logo {width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,var(--navy),#22386b);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;color:#fff;box-shadow:0 2px 8px rgba(0,0,0,.4)}
.heures-mod .brand b {font-size:14px}
.heures-mod .brand span {color:var(--dim);font-size:11px}
.heures-mod .weeknav {margin:0 auto;display:flex;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:5px 8px}
.heures-mod .weeknav button {background:var(--card2);border:1px solid var(--border);color:var(--text);width:28px;height:28px;border-radius:7px;cursor:pointer;font-size:14px}
.heures-mod .weeknav .wk {text-align:center;min-width:200px}
.heures-mod .weeknav .wk b {font-size:13px}
.heures-mod .weeknav .wk div {font-size:10.5px;color:var(--dim);margin-top:1px}
.heures-mod .dlchip {font-size:11px;font-weight:600;padding:5px 10px;border-radius:8px;border:1px solid;white-space:nowrap}
.heures-mod .actions {display:flex;align-items:center;gap:8px}
.heures-mod .btn {font-size:12px;padding:7px 12px;border-radius:8px;border:1px solid var(--border);background:var(--card2);color:var(--text);cursor:pointer;white-space:nowrap;display:flex;gap:6px;align-items:center}
.heures-mod .btn:hover {border-color:#3a4763}
.heures-mod .btn.primary {background:linear-gradient(135deg,var(--red),#c43a30);border-color:#c43a30;font-weight:600;box-shadow:0 2px 10px rgba(226,72,61,.25)}
.heures-mod .btn.ghost {background:transparent}
.heures-mod .btn[disabled] {opacity:.5;cursor:not-allowed}
.heures-mod .search {font-size:12px;padding:7px 10px;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--dim);min-width:150px}
.heures-mod .hbreadcrumb {display:flex;align-items:center;gap:7px;padding:0 2px 9px;font-size:12px;color:var(--dim);flex-wrap:wrap}
.heures-mod .crumb {display:flex;align-items:center;gap:7px;cursor:pointer;color:var(--dim)}
.heures-mod .crumb:hover {color:var(--text)}
.heures-mod .crumb.cur {color:var(--text);font-weight:600;cursor:default}
.heures-mod .crumb .sep {color:var(--muted)}
.heures-mod .crumb .chip {font-size:9.5px;padding:1px 7px;border-radius:5px;border:1px solid}
.heures-mod .hint {margin-left:auto;color:var(--muted);font-size:11px}
.heures-mod .kpis {display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:14px}
.heures-mod .kpi {background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:12px 14px;position:relative;overflow:hidden}
.heures-mod .kpi .n {font-size:23px;font-weight:750;letter-spacing:-.5px}
.heures-mod .kpi .l {font-size:11px;color:var(--dim);margin-top:2px}
.heures-mod .kpi .bar {position:absolute;left:0;top:0;bottom:0;width:3px}
.heures-mod .kpi.k-tot .bar {background:var(--navy)}
.heures-mod .kpi.k-ok .bar {background:var(--s-ok)}
.heures-mod .kpi.k-val .bar {background:var(--s-recu)}
.heures-mod .kpi.k-sai .bar {background:var(--s-saisir)}
.heures-mod .kpi.k-ret .bar {background:var(--s-retard)}
.heures-mod .kpi.k-rev .bar {background:var(--s-ext)}
.heures-mod .smart-queue {display:flex;align-items:center;gap:12px;background:linear-gradient(180deg,rgba(160,108,213,.1),var(--panel));border:1px solid #3a2f4d;border-radius:12px;padding:10px 14px;margin-bottom:14px}
.heures-mod .smart-queue .sqi {font-size:18px}
.heures-mod .smart-queue b {font-size:12.5px}
.heures-mod .smart-queue small {color:var(--dim);font-size:11px}
.heures-mod .smart-queue .sp {margin-left:auto;display:flex;gap:8px}
.heures-mod .sqchip {display:flex;align-items:center;gap:7px;background:var(--card);border:1px solid var(--border);border-radius:9px;padding:5px 9px;cursor:pointer;font-size:11.5px}
.heures-mod .sqchip:hover {border-color:var(--s-ext)}
.heures-mod .sqthumb {width:30px;height:38px;border-radius:5px;background:repeating-linear-gradient(135deg,#2a3550,#2a3550 4px,#243049 4px,#243049 8px);display:flex;align-items:center;justify-content:center;font-size:13px;transform:rotate(-3deg)}
.heures-mod .prio {background:linear-gradient(180deg,rgba(240,86,75,.07),var(--panel));border:1px solid #3a2b2f;border-radius:12px;padding:11px 13px;margin-bottom:14px}
.heures-mod .prio .ph {display:flex;align-items:center;gap:10px;margin-bottom:10px}
.heures-mod .prio .ph b {font-size:12.5px}
.heures-mod .prio .ph small {color:var(--dim);font-weight:400;font-size:11px}
.heures-mod .prio .ph .sp {margin-left:auto;display:flex;gap:8px}
.heures-mod .pgrid {display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:8px}
.heures-mod .pcard {display:grid;grid-template-columns:28px minmax(0,1fr) auto 24px;align-items:center;gap:9px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:7px 10px;cursor:pointer}
.heures-mod .pcard.phero {border-color:var(--s-retard);background:rgba(240,86,75,.1)}
.heures-mod .pinfo {min-width:0}
.heures-mod .pcard .nm {font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.heures-mod .pcard .mt {font-size:10px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.heures-mod .rchip {font-size:9.5px;padding:1px 8px;border-radius:5px;border:1px solid;white-space:nowrap;justify-self:end}
.heures-mod .prel {font-size:12px;border:1px solid #2f6b4a;background:rgba(52,199,123,.12);color:var(--s-ok);border-radius:6px;padding:1px 4px;cursor:pointer;text-align:center}
.heures-mod .pmore {display:flex;align-items:center;justify-content:center;color:var(--dim);font-size:11px;border-style:dashed}
.heures-mod .relance {font-size:11px;padding:5px 10px;border-radius:7px;border:1px solid #2f6b4a;background:rgba(52,199,123,.12);color:var(--s-ok);cursor:pointer;white-space:nowrap}
.heures-mod .relance.em {border-color:#35507e;background:rgba(77,141,240,.12);color:#7fb0f5}
.heures-mod .reventry {display:flex;align-items:center;gap:12px;background:linear-gradient(180deg,rgba(160,108,213,.08),var(--panel));border:1px solid #3a2f4d;border-radius:12px;padding:11px 14px;margin-bottom:16px;cursor:pointer}
.heures-mod .reventry:hover {border-color:var(--s-ext)}
.heures-mod .reventry b {font-size:12.5px}
.heures-mod .reventry small {color:var(--dim);font-size:11px}
.heures-mod .reventry .sp {margin-left:auto;color:var(--s-ext);font-size:12px}
.heures-mod .board {column-count:3;column-gap:14px}
@media(max-width:1180px) {
.heures-mod .board {column-count:2}

}
.heures-mod .group {break-inside:avoid;background:var(--panel);border:1px solid var(--border);border-radius:12px;margin:0 0 14px;overflow:hidden;cursor:pointer}
.heures-mod .group:hover {border-color:#3a4763}
.heures-mod .ghead {display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border)}
.heures-mod .ghead .cn {font-size:13px;font-weight:650;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.heures-mod .ghead .tag {font-size:9px;padding:1px 6px;border-radius:5px;border:1px solid}
.heures-mod .ghead .cnt {font-size:11px;color:var(--dim)}
.heures-mod .ghead .go {color:var(--muted);font-size:14px}
.heures-mod .mini {height:4px;border-radius:3px;background:var(--card2);overflow:hidden;display:flex;margin:0 12px 8px}
.heures-mod .mini i {display:block;height:100%}
.heures-mod .rows {padding:4px 6px 8px}
.heures-mod .grow {display:grid;grid-template-columns:24px minmax(0,1fr) 64px 48px;align-items:center;gap:8px;padding:5px 8px;border-radius:8px}
.heures-mod .grow:hover {background:var(--card)}
.heures-mod .grow.hero {background:rgba(240,86,75,.07);box-shadow:inset 3px 0 0 var(--s-retard)}
.heures-mod .av {width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:9.5px;font-weight:700;color:#fff;flex:none}
.heures-mod .who {min-width:0}
.heures-mod .who .nm {font-size:12px;font-weight:550;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.heures-mod .who .mt {font-size:10px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.heures-mod .estat {text-align:center;font-size:9.5px;line-height:16px;border-radius:5px;border:1px solid;padding:1px 4px;box-sizing:border-box;white-space:nowrap}
.heures-mod .hcell {text-align:right;font-variant-numeric:tabular-nums;font-size:11.5px;font-weight:650}
.heures-mod .hdash {color:var(--muted)}
.heures-mod .cvhead {background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:0;overflow:hidden;margin-bottom:12px}
.heures-mod .cvtop {display:flex;align-items:center;gap:12px;padding:13px 16px}
.heures-mod .cvtop b {font-size:16px}
.heures-mod .cvtop .sub {font-size:11.5px;color:var(--dim);margin-top:2px}
.heures-mod .cvtop .chip {font-size:10.5px;padding:2px 9px;border-radius:6px;border:1px solid}
.heures-mod .dkstrip {display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--border);border-top:1px solid var(--border)}
.heures-mod .dk {background:var(--panel);padding:9px 14px}
.heures-mod .dkn {font-size:20px;font-weight:750;letter-spacing:-.5px;font-variant-numeric:tabular-nums}
.heures-mod .dkl {font-size:10px;color:var(--dim);margin-top:1px}
.heures-mod .blkbox {margin:0;background:rgba(240,86,75,.07);border-top:1px solid #3a2b2f;padding:9px 16px}
.heures-mod .blkbox.ok {background:rgba(52,199,123,.06)}
.heures-mod .blkrow {display:flex;flex-wrap:wrap;gap:6px;margin-top:7px}
.heures-mod .blkchip {font-size:11px;padding:3px 8px;border-radius:6px;border:1px solid #5a2f31;background:rgba(240,86,75,.1);color:#f2a59f;display:flex;align-items:center;gap:5px}
.heures-mod .blkchip .prel {padding:0 3px;font-size:11px}
.heures-mod .client-split {display:grid;grid-template-columns:minmax(0,1fr) 452px;gap:12px;align-items:start}
@media(max-width:1240px) {
.heures-mod .client-split {grid-template-columns:1fr}
.heures-mod .doc-panel {position:fixed;right:0;top:0;bottom:0;width:440px;max-width:92vw;z-index:45;border-radius:0;margin:0;box-shadow:-18px 0 50px rgba(0,0,0,.6)}
.heures-mod .doc-panel.hidden {display:none}

}
.heures-mod .panel-card {background:var(--panel);border:1px solid var(--border);border-radius:14px;overflow:hidden}
.heures-mod .mtbl {width:100%;border-collapse:collapse;font-size:12.5px}
.heures-mod .mtbl th {text-align:left;font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:.4px;padding:8px 10px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--panel)}
.heures-mod .mtbl td {padding:7px 10px;border-bottom:1px solid var(--border);vertical-align:middle}
.heures-mod .mtbl tr.r {cursor:pointer}
.heures-mod .mtbl tr.r:hover {background:var(--card)}
.heures-mod .mtbl tr.sel {background:rgba(46,77,142,.18);box-shadow:inset 3px 0 0 var(--navy)}
.heures-mod .mtbl tr.rmiss {background:rgba(240,86,75,.04)}
.heures-mod .mtbl td.cct {display:flex;align-items:center;gap:8px;min-width:0}
.heures-mod .mtbl .nm {font-size:12.5px;font-weight:550}
.heures-mod .mtbl .mut {color:var(--muted);font-size:10px}
.heures-mod .selbox {width:15px;height:15px;border-radius:4px;border:1px solid var(--muted);display:inline-flex;align-items:center;justify-content:center;font-size:10px;color:transparent;cursor:pointer;flex:none}
.heures-mod .selbox.on {background:var(--s-ok);border-color:var(--s-ok);color:#06210f}
.heures-mod .selbox.off2 {opacity:.35}
.heures-mod .hwrap {display:flex;align-items:center;gap:8px}
.heures-mod .spark {display:flex;align-items:flex-end;gap:2px;height:24px;width:46px;flex:none}
.heures-mod .spark i {flex:1;border-radius:2px;min-height:3px}
.heures-mod .htot {font-size:13px;font-weight:700;font-variant-numeric:tabular-nums}
.heures-mod .htot small {font-size:9px;color:var(--dim);font-weight:500;margin-left:1px}
.heures-mod .ibadge {display:inline-block;font-size:9px;padding:1px 5px;border-radius:5px;border:1px solid #2f6b4a;background:rgba(52,199,123,.1);color:var(--s-ok);margin-right:3px;white-space:nowrap}
.heures-mod .ibadge.ind {border-color:#7a5a2f;background:rgba(242,163,60,.12);color:var(--s-saisir)}
.heures-mod .miss {color:var(--s-retard);font-size:11px;font-weight:600}
.heures-mod .kinp {background:var(--card2);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:4px 7px;font-size:11.5px;width:118px}
.heures-mod .kinp:focus {border-color:var(--s-ok);outline:none}
.heures-mod .cpk {cursor:pointer;color:var(--s-recu);font-size:10px;margin-left:5px;white-space:nowrap}
.heures-mod .fz3 {display:inline-flex;gap:3px;align-items:center;white-space:nowrap}
.heures-mod .fz3 .fb {cursor:pointer;font-size:10px;padding:1px 6px;border-radius:5px;border:1px solid}
.heures-mod .fz3 .ok {color:var(--s-ok);border-color:#2f6b4a;background:rgba(52,199,123,.1)}
.heures-mod .fz3 .re {color:var(--s-recu);border-color:#35507e;background:rgba(77,141,240,.1)}
.heures-mod .fz3 .ex {color:var(--s-ext);border-color:#4d3a63;background:rgba(160,108,213,.1)}
.heures-mod .xmode {cursor:pointer;color:var(--muted);font-size:14px;padding:2px 4px;border-radius:5px}
.heures-mod .xmode:hover {background:var(--card2);color:var(--text)}
.heures-mod .xtag {font-size:8.5px;padding:0 5px;border-radius:4px;border:1px solid;white-space:nowrap}
.heures-mod .doc-panel {background:var(--panel);border:1px solid var(--border);border-radius:14px;overflow:hidden;position:sticky;top:96px}
.heures-mod .dphead {display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border)}
.heures-mod .dphead .nm {font-size:12.5px;font-weight:650;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.heures-mod .dpclose {display:none;cursor:pointer;color:var(--dim);border:1px solid var(--border);background:var(--card2);border-radius:7px;width:26px;height:26px;align-items:center;justify-content:center}
@media(max-width:1240px) {
.heures-mod .dpclose {display:flex}

}
.heures-mod .vw-tabs {display:flex;gap:4px;padding:8px 10px 0}
.heures-mod .vw-tab {font-size:11.5px;padding:6px 11px;border-radius:8px 8px 0 0;border:1px solid var(--border);border-bottom:none;background:var(--card);color:var(--dim);cursor:pointer}
.heures-mod .vw-tab.on {background:var(--card2);color:var(--text)}
.heures-mod .dpbody {padding:10px 12px 12px;min-height:300px}
.heures-mod .docframe {background:#0a0e17;border:1px solid var(--border);border-radius:10px;padding:12px;min-height:320px;display:flex;align-items:center;justify-content:center}
.heures-mod .sheet {background:#f5f6f8;color:#1f2733;border-radius:6px;width:100%;max-width:330px;padding:0;box-shadow:0 8px 26px rgba(0,0,0,.5);overflow:hidden;font-size:11px}
.heures-mod .sheet .sh {padding:9px 12px;color:#fff;display:flex;align-items:center;justify-content:space-between}
.heures-mod .sheet .sb {padding:10px 12px}
.heures-mod .sheet .sr {display:flex;justify-content:space-between;border-bottom:1px solid #e2e5ea;padding:3px 0}
.heures-mod .sheet .sr.tot {border-bottom:none;font-weight:700;color:#193A6A;padding-top:6px}
.heures-mod .sheet .meta {font-size:10px;color:#5a6678;margin-bottom:6px}
.heures-mod .photo {width:100%;max-width:300px;aspect-ratio:3/4;border-radius:8px;background:repeating-linear-gradient(132deg,#283145,#283145 10px,#222a3c 10px,#222a3c 20px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;transform:rotate(-1.4deg);box-shadow:0 8px 26px rgba(0,0,0,.5);position:relative}
.heures-mod .photo .pl {font-size:30px;opacity:.8}
.heures-mod .photo .ll {position:absolute;left:14%;right:14%;height:7px;background:rgba(255,255,255,.07);border-radius:3px}
.heures-mod .csvtbl {width:100%;border-collapse:collapse;font-size:11.5px}
.heures-mod .csvtbl th {text-align:left;font-size:9px;color:var(--dim);text-transform:uppercase;letter-spacing:.3px;padding:5px 6px;border-bottom:1px solid var(--border)}
.heures-mod .csvtbl td {padding:4px 6px;border-bottom:1px solid var(--border);font-variant-numeric:tabular-nums}
.heures-mod .csvtbl tr.ind td {color:var(--s-saisir)}
.heures-mod .csvtbl tr.rep td {color:var(--s-ok)}
.heures-mod .csvtbl tr.tot td {font-weight:700;color:var(--text);border-bottom:none}
.heures-mod .code {font-family:ui-monospace,Menlo,monospace;font-size:10.5px;color:var(--s-recu);background:rgba(77,141,240,.1);padding:0 5px;border-radius:4px}
.heures-mod .dptool {display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.heures-mod .dptool .tb {font-size:10.5px;padding:4px 9px;border-radius:7px;border:1px solid var(--border);background:var(--card2);color:var(--dim);cursor:pointer}
.heures-mod .dptool .tb:hover {color:var(--text);border-color:#3a4763}
.heures-mod .dpempty {display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--dim);font-size:12.5px;text-align:center;padding:40px 10px}
.heures-mod .blkmini {margin-top:9px;display:flex;flex-wrap:wrap;gap:5px}
.heures-mod .bchip {font-size:9.5px;padding:1px 7px;border-radius:5px;border:1px solid}
.heures-mod .client-footer {display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:11px 14px;margin-top:12px}
.heures-mod .client-footer .ft {font-size:11.5px;color:var(--dim)}
.heures-mod .client-footer .sp {margin-left:auto;display:flex;gap:8px}
.heures-mod .rvbuckets {display:flex;gap:8px;margin-bottom:14px}
.heures-mod .rvb {flex:1;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:11px 14px;cursor:pointer}
.heures-mod .rvb.on {border-color:var(--s-ext)}
.heures-mod .rvb .n {font-size:20px;font-weight:750}
.heures-mod .rvb .l {font-size:11px;color:var(--dim)}
.heures-mod .review-card {background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:12px 14px;margin-bottom:10px;display:grid;grid-template-columns:54px 1fr auto;gap:12px;align-items:center}
.heures-mod .review-card .pdfm {width:54px;height:68px;border-radius:7px;background:linear-gradient(135deg,#2a3550,#1c2334);display:flex;align-items:center;justify-content:center;font-size:22px}
.heures-mod .review-card .rc-nm {font-size:13px;font-weight:600}
.heures-mod .review-card .rc-mt {font-size:11px;color:var(--muted);margin-top:2px}
.heures-mod .cand {font-size:11px;color:var(--dim);margin-top:5px}
.heures-mod .cand b {color:var(--text)}
.heures-mod .cand-btn {display:inline-flex;align-items:center;gap:4px;font-size:11.5px;color:var(--text);background:rgba(77,141,240,.12);border:1px solid #35507e;border-radius:7px;padding:4px 9px;margin:0 6px 4px 0;cursor:pointer}
.heures-mod .cand-btn:hover {background:rgba(77,141,240,.22);border-color:var(--s-recu)}
.heures-mod .legend {display:flex;gap:14px;flex-wrap:wrap;margin:0 2px 14px;font-size:11px;color:var(--dim)}
.heures-mod .legend span {display:flex;align-items:center;gap:6px}
.heures-mod .ovl {position:fixed;inset:0;z-index:40}
.heures-mod .mbg {position:fixed;inset:0;background:rgba(5,8,14,.66);z-index:60}
.heures-mod .mcard {position:fixed;z-index:61;top:50%;left:50%;transform:translate(-50%,-50%);max-width:94vw;max-height:90vh;overflow:auto;background:var(--panel);border:1px solid var(--border);border-radius:16px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.heures-mod .mhead {display:flex;align-items:center;gap:12px;padding:15px 18px;border-bottom:1px solid var(--border)}
.heures-mod .mtitle {flex:1;min-width:0}
.heures-mod .mtitle b {font-size:15px}
.heures-mod .mtitle div {font-size:11.5px;color:var(--dim);margin-top:2px}
.heures-mod .mclose {cursor:pointer;color:var(--dim);font-size:20px;border:1px solid var(--border);background:var(--card2);border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center}
.heures-mod .ccard {background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px 14px}
.heures-mod .cch {display:flex;align-items:center;gap:8px;margin-bottom:8px}
.heures-mod .cch b {font-size:13px}
.heures-mod .crowo {display:flex;align-items:center;gap:8px;font-size:12px;padding:5px 0;border-bottom:1px solid var(--border)}
.heures-mod .crowo>span:first-child {width:120px;color:var(--dim);flex:none}
.heures-mod .crowo input {flex:1;min-width:0;background:var(--card2);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:4px 7px;font-size:11.5px}
.heures-mod .ba {display:grid;grid-template-columns:1fr 1fr;gap:12px}
.heures-mod .baimg {border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#0a0e17;padding:10px;display:flex;flex-direction:column;align-items:center;gap:8px}
.heures-mod .baimg .cap {font-size:10.5px;color:var(--dim)}
.heures-mod .ctp {display:flex;align-items:center;gap:10px;padding:7px 9px;border-radius:8px;cursor:pointer;font-size:12.5px}
.heures-mod .ctp:hover {background:var(--card)}
.heures-mod .toast {position:fixed;right:20px;bottom:20px;background:#0b1424;border:1px solid var(--s-ok);color:var(--text);padding:11px 15px;border-radius:10px;font-size:12.5px;opacity:0;transition:opacity .2s;box-shadow:0 10px 30px rgba(0,0,0,.5);z-index:99;pointer-events:none;max-width:380px}
.heures-mod .footnote {margin-top:22px;color:var(--muted);font-size:10.5px;text-align:center}
.heures-mod {}
.heures-mod .growmore {text-align:center; color:var(--muted); font-size:10.5px; padding:3px;}
.heures-mod .searchrow {display:grid; grid-template-columns:28px minmax(0,1fr) 220px 78px 64px; align-items:center; gap:10px; cursor:pointer; background:var(--card); border:1px solid var(--border); border-radius:10px; margin-bottom:7px; padding:9px 12px;}
.heures-mod .searchrow .scl {font-size:11.5px; color:var(--dim); overflow:hidden; text-overflow:ellipsis; white-space:nowrap;}
.heures-mod .searchrow span:last-child {text-align:right;}
.heures-mod .csvmono {font-family:ui-monospace,Menlo,monospace; font-size:10px; color:#9fe6c2; width:100%; line-height:1.95; word-break:break-all;}
.heures-mod .csvhead {color:#6b7a90; margin-bottom:5px; border-bottom:1px solid #243049; padding-bottom:4px;}

/* ── File de réconciliation : onglets Mails / Photos (P2-A) ── */
.heures-mod .rv-tabs {display:flex; gap:8px; margin-bottom:16px; border-bottom:1px solid var(--border);}
.heures-mod .rv-tab {font-size:12.5px; color:var(--dim); padding:8px 14px; cursor:pointer; border-bottom:2px solid transparent; display:flex; align-items:center; gap:7px; margin-bottom:-1px;}
.heures-mod .rv-tab:hover {color:var(--text);}
.heures-mod .rv-tab.on {color:var(--text); border-bottom-color:var(--red); font-weight:600;}
.heures-mod .rv-tab b {font-size:11px; background:var(--card2); border:1px solid var(--border); border-radius:20px; padding:1px 8px; color:var(--text); font-weight:600;}
.heures-mod .rv-tab.on b {background:rgba(226,72,61,.16); border-color:#c43a30; color:#ffb3ad;}

/* ── Carte réconciliation-photo : image redressée à gauche, candidats à droite ── */
.heures-mod .ph-card {display:grid; grid-template-columns:300px 1fr; gap:16px; background:var(--panel); border:1px solid var(--border); border-radius:14px; padding:14px; margin-bottom:14px; align-items:stretch;}
.heures-mod .ph-card.redo {border-color:#7a5a2f; box-shadow:0 0 0 1px rgba(242,163,60,.15);}
.heures-mod .ph-left {display:flex; flex-direction:column; gap:8px;}
.heures-mod .ph-imgbox, .heures-mod .ph-imgframe {width:100%; height:380px; border-radius:10px; border:1px solid var(--border); background:#0a0e17;}
.heures-mod .ph-imgframe {display:block;}
.heures-mod .ph-imgbox {display:flex; align-items:center; justify-content:center;}
.heures-mod .ph-imgmsg {color:var(--dim); font-size:12px; text-align:center; line-height:1.6;}
.heures-mod .ph-tools {display:flex; gap:8px; align-items:center; flex-wrap:wrap;}
.heures-mod .ph-tools a.btn {text-decoration:none;}
.heures-mod .ph-redo {font-size:10.5px; font-weight:600; color:var(--s-saisir); border:1px solid #7a5a2f; background:rgba(242,163,60,.12); border-radius:7px; padding:4px 9px;}
.heures-mod .ph-right {display:flex; flex-direction:column; min-width:0;}
.heures-mod .ph-from {font-size:13px; word-break:break-all;}
.heures-mod .ph-from b {color:var(--text);}
.heures-mod .ph-date {color:var(--dim); font-size:11.5px;}
.heures-mod .ph-hint {font-size:11.5px; color:var(--dim); margin:7px 0 12px; line-height:1.55;}
.heures-mod .ph-hint b {color:var(--text);}
.heures-mod .ph-cands {display:flex; flex-wrap:wrap; gap:6px;}

/* ── P2-C : bandeau apprentissage + jauge/relance par client ── */
.heures-mod .learnbanner {display:flex; align-items:center; gap:10px; background:linear-gradient(180deg,rgba(52,199,123,.08),var(--panel)); border:1px solid #2f6b4a; border-radius:12px; padding:9px 14px; margin-bottom:16px;}
.heures-mod .learnbanner span {font-size:16px;}
.heures-mod .learnbanner b {font-size:12.5px; color:var(--s-ok);}
.heures-mod .learnbanner small {color:var(--dim); font-size:11px;}
.heures-mod .gdl {font-size:10px; font-weight:600; padding:1px 6px; border-radius:6px; border:1px solid; white-space:nowrap;}
.heures-mod .gmiss {display:flex; align-items:center; gap:10px; margin-top:7px; padding-top:7px; border-top:1px dashed var(--border);}
.heures-mod .gmlbl {font-size:11px; font-weight:600;}
.heures-mod .grel {margin-left:auto; font-size:11px; color:var(--s-recu); border:1px solid #35507e; background:rgba(77,141,240,.1); border-radius:7px; padding:3px 9px; cursor:pointer; white-space:nowrap;}
.heures-mod .grel:hover {background:rgba(77,141,240,.2);}
.heures-mod .blkhd {display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:6px;}
