:root{
  --navy:#123e73;--navy-2:#0b2d56;--blue:#1f6fc2;--sky:#eaf3fc;--ink:#172033;--muted:#6f7b8f;
  --line:#dfe6ef;--panel:#fff;--bg:#f3f6fa;--green:#2c9a65;--orange:#e78a22;--red:#d84b4b;--violet:#7459c8;
  --shadow:0 12px 30px rgba(20,48,82,.08);--radius:18px;
}
*{box-sizing:border-box}html{background:var(--bg)}body{margin:0;font-family:Inter,ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:var(--bg);font-size:14px}
button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:100vh}
.sidebar{position:sticky;top:0;height:100vh;background:linear-gradient(180deg,var(--navy-2),var(--navy));color:#fff;padding:24px 18px;display:flex;flex-direction:column;z-index:20}
.brand{display:flex;gap:12px;align-items:center;padding:2px 8px 28px}.brand-mark{width:43px;height:43px;border-radius:13px;background:#fff;color:var(--navy);display:grid;place-items:center;font-weight:900;box-shadow:0 8px 24px rgba(0,0,0,.18)}.brand strong{display:block;font-size:16px}.brand span{display:block;color:#bad0e8;font-size:11px;margin-top:3px}
.nav{display:grid;gap:6px}.nav-item{border:0;background:transparent;color:#d6e4f3;text-align:left;border-radius:12px;padding:12px 13px;font-weight:700;display:flex;gap:12px;align-items:center}.nav-item span{font-size:18px;width:20px;text-align:center}.nav-item:hover,.nav-item.active{background:rgba(255,255,255,.13);color:#fff}.nav-item.active{box-shadow:inset 3px 0 #7fc5ff}
.filter-panel{margin-top:28px;padding:20px 8px 0;border-top:1px solid rgba(255,255,255,.16);display:grid;gap:13px}.section-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#9eb8d3;font-weight:800}.filter-panel label{display:grid;gap:6px;color:#d9e7f4;font-size:11px;font-weight:700}.filter-panel input,.filter-panel select{width:100%;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.1);color:#fff;border-radius:10px;padding:10px 11px;outline:none}.filter-panel select option{color:#111}.filter-panel input::placeholder{color:#a9bdd2}.sidebar-foot{margin-top:auto;padding:20px 8px 0}.privacy-note{display:flex;gap:10px;align-items:flex-start;background:rgba(255,255,255,.08);padding:12px;border-radius:12px}.privacy-note>span{color:#68d391}.privacy-note strong{font-size:11px;display:block}.privacy-note small{display:block;color:#b8cce0;line-height:1.35;margin-top:3px}
.main{min-width:0}.topbar{height:96px;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:15}.page-title h1{font-size:25px;margin:2px 0 0}.eyebrow{font-size:10px;letter-spacing:.12em;color:var(--blue);font-weight:900}.topbar-actions{display:flex;align-items:center;gap:10px}.month-picker{display:grid;gap:3px;font-size:10px;color:var(--muted);font-weight:800}.month-picker select{min-width:130px;border:1px solid var(--line);border-radius:9px;padding:8px 10px;background:#fff;color:var(--ink)}
.btn{border:1px solid transparent;border-radius:10px;padding:10px 14px;font-weight:800;font-size:12px;transition:.15s}.btn:hover{transform:translateY(-1px)}.btn.primary{background:var(--blue);color:#fff;box-shadow:0 7px 18px rgba(31,111,194,.2)}.btn.secondary{background:#edf4fb;color:var(--navy);border-color:#d6e6f5}.btn.ghost{background:transparent;color:inherit;border-color:var(--line)}.sidebar .btn.ghost{border-color:rgba(255,255,255,.25);color:#fff}.btn.danger{background:#fff0f0;color:#b72c2c;border-color:#ffd0d0}.btn.full{width:100%}.icon-btn{width:38px;height:38px;border:1px solid var(--line);border-radius:10px;background:#fff;display:grid;place-items:center;color:var(--ink);font-weight:900;font-size:18px}.hidden{display:none!important}.spacer{flex:1}.mobile-only{display:none}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;padding:24px 32px 8px}.kpi-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:17px 18px;display:flex;align-items:center;gap:14px;box-shadow:0 5px 18px rgba(20,48,82,.035)}.kpi-icon{width:43px;height:43px;border-radius:13px;display:grid;place-items:center;font-size:20px;background:var(--sky);color:var(--blue)}.kpi-card strong{display:block;font-size:23px}.kpi-card span{font-size:11px;color:var(--muted);font-weight:700}.kpi-card.alert .kpi-icon{background:#fff0f0;color:var(--red)}.kpi-card.warning .kpi-icon{background:#fff6e8;color:var(--orange)}.kpi-card.success .kpi-icon{background:#eaf8f1;color:var(--green)}
.workspace-head{display:flex;justify-content:space-between;align-items:end;padding:23px 32px 16px}.workspace-head h2{margin:0 0 5px;font-size:18px}.workspace-head p{margin:0;color:var(--muted);font-size:12px}.workspace-actions{display:flex;gap:8px}.content{padding:0 32px 36px}
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(285px,1fr));gap:16px}.person-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:17px;box-shadow:0 6px 20px rgba(22,48,78,.045);position:relative;overflow:hidden}.person-card::before{content:"";height:4px;position:absolute;left:0;right:0;top:0;background:var(--status-color,#aab5c4)}.person-top{display:flex;gap:13px;align-items:center}.avatar{width:57px;height:57px;border-radius:50%;display:grid;place-items:center;flex:none;background:linear-gradient(145deg,#dcecff,#b7d3ef);color:var(--navy);font-size:17px;font-weight:900;object-fit:cover;border:3px solid #fff;box-shadow:0 0 0 1px #dce5ee}.person-name{min-width:0;flex:1}.person-name h3{margin:0 0 4px;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.person-name p{margin:0;color:var(--muted);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.load-ring{--p:0;--ring:#9aa8ba;width:57px;height:57px;border-radius:50%;background:conic-gradient(var(--ring) calc(var(--p)*1%),#edf1f5 0);display:grid;place-items:center;position:relative;flex:none}.load-ring::after{content:"";position:absolute;inset:6px;background:#fff;border-radius:50%}.load-ring strong{position:relative;z-index:1;font-size:11px;text-align:center;line-height:1.1}.status-row{display:flex;justify-content:space-between;align-items:center;margin:15px 0 10px}.status-pill{font-size:10px;font-weight:900;padding:5px 8px;border-radius:999px;background:#eef2f6;color:#5d6a7a}.status-pill.under{background:#e9f3ff;color:#1d69ad}.status-pill.balanced{background:#e9f8f1;color:#22794f}.status-pill.high{background:#fff4e3;color:#b46b11}.status-pill.over{background:#fff0f0;color:#b42f2f}.status-pill.unknown{background:#f1eefb;color:#6550a6}.unknown-note{font-size:10px;color:var(--muted)}
.alloc-list{display:grid;gap:7px;min-height:58px}.alloc-item{display:grid;grid-template-columns:9px minmax(0,1fr) auto;gap:8px;align-items:center;border:1px solid #edf1f5;background:#fafbfd;border-radius:10px;padding:8px 9px;cursor:pointer}.alloc-item:hover{border-color:#bcd3ea;background:#f4f9fe}.alloc-dot{width:8px;height:8px;border-radius:50%;background:var(--blue)}.alloc-item.absence .alloc-dot{background:var(--red)}.alloc-item.availability .alloc-dot{background:var(--green)}.alloc-item.internal .alloc-dot{background:var(--violet)}.alloc-label{font-size:11px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.alloc-rate{font-size:10px;font-weight:900;color:var(--navy)}.tentative .alloc-label::after{content:" · à confirmer";color:var(--orange);font-weight:800}.person-actions{display:flex;gap:8px;margin-top:13px}.person-actions .btn{flex:1;padding:8px}.more-count{font-size:10px;color:var(--muted);text-align:center;padding:3px}.empty-mini{font-size:11px;color:var(--muted);padding:15px;text-align:center;border:1px dashed var(--line);border-radius:10px}
.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:17px}.project-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.project-cover{height:118px;position:relative;background:linear-gradient(135deg,#113d71,#3f82c3);display:flex;align-items:flex-end;padding:15px;color:white;background-size:cover;background-position:center}.project-cover::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(5,24,47,.72))}.project-cover>*{position:relative;z-index:1}.project-cover h3{margin:0;font-size:17px;max-width:90%}.project-cover .project-edit{position:absolute;right:10px;top:10px;background:rgba(255,255,255,.9);color:var(--ink);border:0;border-radius:9px;width:34px;height:34px}.project-body{padding:15px}.project-meta{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px}.tag{font-size:10px;font-weight:800;padding:5px 8px;border-radius:999px;background:#eef4fa;color:#45637e}.tag.tentative{background:#fff4e2;color:#a7630c}.face-stack{display:flex;align-items:center}.mini-avatar{width:32px;height:32px;border-radius:50%;border:2px solid #fff;margin-left:-8px;background:#dbeafa;display:grid;place-items:center;font-size:9px;font-weight:900;color:var(--navy);object-fit:cover}.mini-avatar:first-child{margin-left:0}.project-count{font-size:11px;color:var(--muted);margin-left:9px}.project-allocs{display:grid;gap:7px;margin-top:12px}.project-person{display:flex;justify-content:space-between;gap:10px;border-top:1px solid #edf1f5;padding-top:8px;font-size:11px}.project-person strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-person span{color:var(--muted);white-space:nowrap}
.table-wrap{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:auto;box-shadow:var(--shadow);max-height:calc(100vh - 300px)}.calendar-table{border-collapse:separate;border-spacing:0;min-width:1600px;width:100%;font-size:10px}.calendar-table th,.calendar-table td{border-right:1px solid #e6ebf1;border-bottom:1px solid #e6ebf1;padding:8px;vertical-align:top;min-width:116px;height:78px}.calendar-table thead th{position:sticky;top:0;background:#f0f5fa;z-index:3;color:var(--navy);font-size:10px}.calendar-table th:first-child,.calendar-table td:first-child{position:sticky;left:0;z-index:2;background:#fff;min-width:190px;max-width:190px}.calendar-table thead th:first-child{z-index:4;background:#e9f1f9}.cal-person{display:flex;gap:8px;align-items:center;font-weight:800}.cal-person .avatar{width:31px;height:31px;font-size:9px;border-width:1px}.cal-chip{padding:4px 5px;border-radius:6px;background:#eef5fc;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-left:3px solid var(--blue)}.cal-chip.absence{background:#fff0f0;border-color:var(--red)}.cal-chip.availability{background:#eaf8f1;border-color:var(--green)}.cal-chip.internal{background:#f2effc;border-color:var(--violet)}.cal-total{font-weight:900;color:var(--navy);margin-bottom:5px}
.needs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:14px}.need-card{background:#fff;border:1px solid var(--line);border-radius:15px;padding:16px;box-shadow:0 5px 18px rgba(20,48,82,.04)}.need-card h3{font-size:14px;margin:0 0 10px}.need-status{font-size:9px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:var(--orange)}.need-note{background:#f5f8fb;border-left:3px solid var(--blue);padding:9px;border-radius:7px;font-size:11px;line-height:1.35}.need-empty{color:var(--muted);font-size:11px}
.network-wrap{overflow:auto;background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow)}.network-stage{position:relative;min-width:900px}.network-lines{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.network-grid{display:grid;grid-template-columns:290px 1fr 290px;position:relative;z-index:2}.network-col{display:grid;align-content:start;gap:10px}.network-col.right{grid-column:3}.network-node{height:52px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:7px 10px;display:flex;align-items:center;gap:9px;box-shadow:0 4px 13px rgba(20,48,82,.05)}.network-node .avatar{width:36px;height:36px;font-size:10px;border-width:1px}.network-node strong{font-size:11px;display:block}.network-node small{font-size:9px;color:var(--muted)}.network-project{border-left:4px solid var(--blue)}
.empty-state{background:#fff;border:1px dashed #cbd5e0;border-radius:18px;padding:60px 30px;text-align:center;color:var(--muted)}.empty-state strong{display:block;color:var(--ink);font-size:16px;margin-bottom:6px}
.modal{border:0;border-radius:20px;padding:0;width:min(650px,calc(100vw - 28px));box-shadow:0 30px 90px rgba(4,23,46,.35)}.modal::backdrop{background:rgba(4,24,46,.55);backdrop-filter:blur(3px)}.modal.compact{width:min(570px,calc(100vw - 28px))}.modal form{margin:0}.modal-head{padding:20px 22px 15px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:flex-start}.modal-head h2{margin:3px 0 0}.modal-body{padding:21px 22px;max-height:70vh;overflow:auto}.modal-actions{display:flex;gap:9px;padding:15px 22px 20px;border-top:1px solid var(--line)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px}.form-grid .full{grid-column:1/-1}.form-field{display:grid;gap:6px}.form-field label{font-size:11px;font-weight:800;color:#536174}.form-field input,.form-field select,.form-field textarea{border:1px solid var(--line);border-radius:10px;padding:10px 11px;background:#fff;min-width:0}.form-field textarea{min-height:86px;resize:vertical}.photo-editor{display:flex;gap:14px;align-items:center;border:1px dashed var(--line);padding:12px;border-radius:12px}.photo-editor .avatar{width:65px;height:65px}.photo-editor small{color:var(--muted);display:block;margin-top:4px}.data-actions{display:grid;gap:10px}.data-card{text-align:left;border:1px solid var(--line);background:#fff;border-radius:12px;padding:14px}.data-card:hover{border-color:#9fc4e7;background:#f7fbff}.data-card strong{display:block;color:var(--navy);font-size:13px}.data-card span{display:block;color:var(--muted);font-size:11px;margin-top:4px}.data-card.warning strong{color:#b35912}
.toast{position:fixed;right:24px;bottom:24px;background:#172b46;color:#fff;padding:12px 16px;border-radius:11px;box-shadow:0 12px 30px rgba(0,0,0,.22);transform:translateY(20px);opacity:0;pointer-events:none;transition:.2s;z-index:50;font-weight:700;font-size:12px}.toast.show{transform:none;opacity:1}
@media(max-width:1100px){.app-shell{grid-template-columns:220px minmax(0,1fr)}.sidebar{padding-left:12px;padding-right:12px}.topbar{padding:0 22px}.kpi-grid,.content{padding-left:22px;padding-right:22px}.workspace-head{padding-left:22px;padding-right:22px}.kpi-grid{grid-template-columns:repeat(2,1fr)}.topbar-actions .btn.secondary{display:none}}
@media(max-width:760px){.app-shell{display:block}.sidebar{position:fixed;left:-280px;width:260px;transition:.2s;box-shadow:20px 0 50px rgba(0,0,0,.25)}.sidebar.open{left:0}.main{width:100%}.mobile-only{display:grid}.topbar{height:auto;min-height:92px;padding:14px 14px;gap:10px}.page-title{flex:1}.page-title h1{font-size:18px}.page-title .eyebrow{display:none}.topbar-actions{gap:6px}.topbar-actions .btn{display:none}.month-picker select{min-width:105px}.kpi-grid{padding:15px 14px 5px;grid-template-columns:1fr 1fr;gap:10px}.kpi-card{padding:12px}.kpi-card strong{font-size:18px}.kpi-icon{display:none}.workspace-head{padding:18px 14px 12px;align-items:flex-start}.workspace-actions .btn{display:none}.content{padding:0 14px 25px}.team-grid,.project-grid,.needs-grid{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}.form-grid .full{grid-column:auto}.toast{left:15px;right:15px;bottom:15px}.calendar-table{min-width:1400px}}
@media print{.sidebar,.topbar,.workspace-actions,.person-actions,.project-edit{display:none!important}.app-shell{display:block}.kpi-grid,.workspace-head,.content{padding-left:10mm;padding-right:10mm}.main{background:#fff}.person-card,.project-card,.kpi-card{break-inside:avoid;box-shadow:none}.content{padding-bottom:0}}

/* Congés et continuité des projets */
.leave-action{border-color:#f1c56f!important;color:#9a5a08!important;background:#fff9ed!important}.person-leaves{display:grid;gap:5px;margin:-2px 0 10px}.person-leave{border:0;background:#fff7e8;color:#93570c;border-radius:8px;padding:6px 8px;display:flex;justify-content:space-between;gap:8px;font-size:10px;text-align:left}.person-leave:hover{background:#ffefce}.person-leave strong{white-space:nowrap}.cal-chip.leave{background:#fff5df;border-color:#e8a42c;color:#8a520d;cursor:pointer}.leave-dashboard{display:grid;gap:24px}.leave-section-title{display:flex;justify-content:space-between;align-items:end;gap:18px;margin-bottom:12px}.leave-section-title h3{margin:0 0 4px;font-size:16px}.leave-section-title p{margin:0;color:var(--muted);font-size:11px}.conflict-counter{font-size:11px;font-weight:900;border-radius:999px;padding:7px 10px;white-space:nowrap}.conflict-counter.danger{background:#fff0f0;color:#b52e2e}.conflict-counter.safe{background:#eaf8f1;color:#24764f}.conflict-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.conflict-card{background:#fff;border:1px solid #ffd1d1;border-left:5px solid var(--red);border-radius:15px;padding:16px;box-shadow:0 7px 20px rgba(158,39,39,.06)}.conflict-head{display:flex;align-items:center;gap:10px}.conflict-icon{width:34px;height:34px;display:grid;place-items:center;background:#fff0f0;color:var(--red);border-radius:50%;font-weight:1000;font-size:18px}.conflict-card h3{margin:2px 0 0;font-size:14px}.conflict-period{margin:13px 0;background:#fff6f6;border-radius:9px;padding:9px;font-size:11px}.conflict-people{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:start}.conflict-people>div:last-child{display:flex;flex-wrap:wrap;gap:5px}.conflict-people button{border:0;background:#f1f4f8;border-radius:7px;padding:5px 7px;font-size:10px;font-weight:800;color:var(--ink)}.conflict-card p{margin:11px 0 0;color:var(--muted);font-size:10px}.no-conflict{background:#fff;border:1px solid #cdebdc;border-radius:15px;padding:18px;display:flex;gap:14px;align-items:center}.no-conflict>span{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:#eaf8f1;color:var(--green);font-size:22px;font-weight:900}.no-conflict strong{display:block}.no-conflict p{margin:4px 0 0;color:var(--muted);font-size:11px}.leave-list{display:grid;gap:10px}.leave-person-row{display:grid;grid-template-columns:minmax(210px,260px) minmax(0,1fr) auto;gap:14px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;box-shadow:0 4px 15px rgba(20,48,82,.035)}.leave-person{display:flex;gap:10px;align-items:center;min-width:0}.leave-person .avatar{width:44px;height:44px;font-size:12px}.leave-person strong,.leave-person small{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leave-person small{font-size:10px;color:var(--muted);margin-top:3px}.leave-periods{display:flex;gap:8px;overflow:auto;padding:2px}.leave-period-card{min-width:230px;text-align:left;border:1px solid #f0d5a6;background:#fffaf0;border-radius:11px;padding:9px 11px;display:grid;gap:3px;color:var(--ink)}.leave-period-card:hover{border-color:#e6aa45}.leave-period-card.planned{border-style:dashed}.leave-period-card .leave-type{font-size:9px;text-transform:uppercase;font-weight:900;color:#a4600a;letter-spacing:.05em}.leave-period-card strong{font-size:11px}.leave-period-card small{font-size:9px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leave-period-card em{font-size:9px;color:#6f5b3f;font-style:normal}.legacy-leaves{padding-top:5px}.legacy-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}.legacy-grid article{background:#fff;border:1px dashed #e2bb77;border-radius:12px;padding:12px;display:grid;gap:6px}.legacy-grid strong{font-size:12px}.legacy-grid span{font-size:10px;color:var(--muted);min-height:28px}.legacy-grid .btn{justify-self:start;padding:7px 9px}.compact-empty{padding:28px}.conflict-preview{border-radius:10px;background:#f5f8fb;padding:10px;font-size:10px;font-weight:750}.preview-warning{color:#ae5a08}.preview-ok{color:#23764f}.preview-error{color:#b52e2e}
@media(max-width:760px){.leave-section-title{align-items:flex-start;flex-direction:column}.leave-person-row{grid-template-columns:1fr auto}.leave-periods{grid-column:1/-1;grid-row:2}.leave-period-card{min-width:210px}.conflict-grid{grid-template-columns:1fr}}
@media print{.leave-action,.leave-section-title .btn,.legacy-grid .btn{display:none!important}.leave-person-row,.conflict-card{break-inside:avoid}}
