:root{--waf-primary:#FFD700;--waf-dark:#000;--waf-light:#fff;--waf-bg:#f5f5f5;--waf-card:#fff;--waf-border:#ddd;--waf-text:#111;--waf-muted:#555;--danger:#b91c1c;--success:#166534}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Arial,sans-serif;background:var(--waf-bg);color:var(--waf-text)}a{color:#111;text-decoration:none}.layout{display:flex;min-height:100vh}.sidebar{width:270px;background:#000;color:#fff;position:fixed;top:0;bottom:0;left:0;overflow:auto;border-right:5px solid var(--waf-primary)}.brand{padding:22px;border-bottom:1px solid #333;display:flex;align-items:center;gap:10px}.logo{background:var(--waf-primary);color:#000;font-weight:900;padding:9px 10px;border-radius:12px}.sidebar nav{padding:14px}.sidebar a{display:block;color:#fff;padding:11px 12px;border-radius:12px;margin:3px 0;font-size:14px}.sidebar a:hover{background:var(--waf-primary);color:#000}.main{margin-left:270px;width:calc(100% - 270px)}.topbar{background:#fff;border-top:5px solid var(--waf-primary);border-bottom:1px solid var(--waf-border);padding:15px 22px;display:flex;justify-content:space-between;align-items:center;gap:12px}.topbar h1{margin:0;font-size:22px}.user{font-size:13px;color:var(--waf-muted)}.content{padding:22px}.card{background:var(--waf-card);border:1px solid var(--waf-border);border-radius:18px;padding:18px;margin-bottom:18px;box-shadow:0 8px 24px rgba(0,0,0,.05)}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.kpi{background:#fff;border-left:6px solid var(--waf-primary);border-radius:16px;padding:16px;border-top:1px solid var(--waf-border);box-shadow:0 4px 16px rgba(0,0,0,.04)}.kpi strong{display:block;font-size:28px}.kpi span{color:var(--waf-muted);font-size:13px}.btn{display:inline-block;border:0;background:#000;color:#fff!important;padding:10px 14px;border-radius:12px;font-weight:700;cursor:pointer}.btn.gold{background:var(--waf-primary);color:#000!important}.btn.danger{background:var(--danger)}.actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}table{width:100%;border-collapse:collapse;background:#fff;border-radius:14px;overflow:hidden}th{background:#000;color:var(--waf-primary);text-align:left}th,td{padding:10px;border-bottom:1px solid #e5e5e5;font-size:14px}tr:hover td{background:#fffbe6}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}.field label{display:block;font-weight:700;margin-bottom:6px;font-size:13px}.field input,.field select,.field textarea{width:100%;padding:11px;border:1px solid var(--waf-border);border-radius:12px;background:#fff}.field textarea{min-height:96px}.alert{padding:12px 14px;border-radius:12px;margin-bottom:14px}.alert.success{background:#dcfce7;color:#14532d}.alert.error{background:#fee2e2;color:#7f1d1d}.login-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#000,#333)}.login-card{width:min(430px,92vw);background:#fff;padding:26px;border-radius:24px;border-top:8px solid var(--waf-primary);box-shadow:0 18px 50px rgba(0,0,0,.25)}.login-card h1{margin-top:0}.badge{display:inline-block;padding:4px 8px;border-radius:99px;background:#f3f4f6;font-size:12px}.badge.high,.badge.critical{background:#fee2e2;color:#991b1b}.badge.active,.badge.validated,.badge.done{background:#dcfce7;color:#166534}@media(max-width:850px){.sidebar{position:relative;width:100%;height:auto}.main{margin-left:0;width:100%}.layout{display:block}.topbar{display:block}}

/* Photos employés */
.table-photo{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid var(--waf-primary);background:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:900;color:#000;vertical-align:middle}
.table-photo-empty{background:linear-gradient(135deg,#fff7b0,#FFD700);font-size:12px;letter-spacing:.5px}
.form-photo-preview{width:92px;height:92px;border-radius:18px;object-fit:cover;border:3px solid var(--waf-primary);display:block;margin:8px 0;background:#fff}
.file-current{margin-top:8px;display:flex;flex-direction:column;gap:4px}
.field small{display:block;color:var(--waf-muted);font-size:12px;margin-top:5px;line-height:1.35}

/* Correctif 003 : affichage direct au clic sur un élément */
.clickable-row{cursor:pointer}
.clickable-row:hover td{background:#fff7cc!important}
.row-main-link{display:block;color:inherit;text-decoration:none}
.row-main-link:hover{text-decoration:none;color:#000}
.row-actions{white-space:nowrap}
.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:12px}
.detail-item{border:1px solid var(--waf-border);border-radius:14px;padding:12px;background:#fff}
.detail-item span{display:block;font-size:12px;color:var(--waf-muted);font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.detail-item strong{display:block;font-size:15px;line-height:1.45;word-break:break-word}
.detail-item em{font-style:normal;color:var(--waf-muted);font-weight:500}
.detail-photo{width:130px;height:130px;border-radius:18px;object-fit:cover;border:3px solid var(--waf-primary);background:#fff;display:block}

/* Correctif 004 : forcer les photos à respecter un format raisonnable */
.table-photo,
td img.table-photo{
    width:46px!important;
    height:46px!important;
    min-width:46px!important;
    max-width:46px!important;
    max-height:46px!important;
    border-radius:50%!important;
    object-fit:cover!important;
    object-position:center!important;
    display:inline-flex!important;
    vertical-align:middle!important;
}

.form-photo-preview,
.file-current img.form-photo-preview{
    width:90px!important;
    height:90px!important;
    max-width:90px!important;
    max-height:90px!important;
    border-radius:16px!important;
    object-fit:cover!important;
    object-position:center!important;
    display:block!important;
}

.detail-photo,
.detail-item img.detail-photo{
    width:120px!important;
    height:120px!important;
    max-width:120px!important;
    max-height:120px!important;
    border-radius:18px!important;
    object-fit:cover!important;
    object-position:center!important;
    display:block!important;
}

/* Sécurité : si une image employé sort sans classe, elle ne devient plus géante */
table td img,
.file-current img,
.detail-item img{
    max-width:120px!important;
    max-height:120px!important;
    object-fit:cover!important;
}

/* Les images dans les tableaux restent toujours des miniatures */
table td img{
    width:46px!important;
    height:46px!important;
    border-radius:50%!important;
}

/* Correctif 005 : améliorations JS / interface plus flexible */
body.waf-js-ready .card,
body.waf-js-ready .kpi,
body.waf-js-ready table{
    animation:wafFadeUp .28s ease both;
}
@keyframes wafFadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.sidebar a.is-active{
    background:var(--waf-primary)!important;
    color:#000!important;
    font-weight:900;
    box-shadow:0 8px 18px rgba(255,215,0,.18);
}

.js-search-box{
    width:100%;
    padding:11px 12px;
    border:1px solid var(--waf-border);
    border-radius:12px;
    margin-bottom:12px;
    background:#fff;
    font-weight:600;
}

.table-toolbar{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
    margin-bottom:10px;
}
.table-counter{
    font-size:12px;
    color:var(--waf-muted);
    font-weight:800;
    background:#fff7cc;
    border:1px solid #f0d25c;
    border-radius:99px;
    padding:7px 10px;
}

.clickable-row td{
    transition:background .18s ease, transform .18s ease;
}
.clickable-row:hover td{
    background:#fff3b0!important;
}
.clickable-row.row-selected td{
    background:#fff0a3!important;
}

.btn{
    transition:transform .16s ease, box-shadow .16s ease, opacity .16s ease;
}
.btn:hover{
    transform:translateY(-1px);
    box-shadow:0 8px 18px rgba(0,0,0,.12);
}

.toast-area{
    position:fixed;
    right:18px;
    bottom:18px;
    z-index:9999;
    display:flex;
    flex-direction:column;
    gap:8px;
    max-width:min(360px,90vw);
}
.toast-msg{
    background:#111;
    color:#fff;
    border-left:5px solid var(--waf-primary);
    padding:12px 14px;
    border-radius:14px;
    box-shadow:0 12px 30px rgba(0,0,0,.22);
    font-size:13px;
    animation:wafToastIn .22s ease both;
}
@keyframes wafToastIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}

.confirm-backdrop{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.45);
    z-index:9998;
    display:grid;
    place-items:center;
    padding:18px;
}
.confirm-box{
    width:min(420px,94vw);
    background:#fff;
    border-radius:20px;
    border-top:7px solid var(--waf-primary);
    box-shadow:0 24px 70px rgba(0,0,0,.35);
    padding:20px;
    animation:wafFadeUp .2s ease both;
}
.confirm-box h3{margin:0 0 8px;font-size:20px}
.confirm-box p{margin:0 0 18px;color:var(--waf-muted);line-height:1.45}
.confirm-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}

.photo-live-preview{
    width:110px!important;
    height:110px!important;
    border-radius:18px!important;
    object-fit:cover!important;
    border:3px solid var(--waf-primary)!important;
    display:block!important;
    margin-top:8px!important;
    background:#fff!important;
    box-shadow:0 8px 20px rgba(0,0,0,.08);
}

.field.focused label{color:#000}
.field.focused input,
.field.focused select,
.field.focused textarea{
    border-color:var(--waf-primary)!important;
    box-shadow:0 0 0 4px rgba(255,215,0,.18);
    outline:none;
}

@media(max-width:850px){
    .content{padding:14px}
    .table-toolbar{display:block}
    .js-search-box{margin-top:8px}
}

/* =========================================================
   Correctif 007 : affichage professionnel des fiches + logo WAF
   Charte officielle : Noir / Or / Blanc
   ========================================================= */
.brand{
    padding:18px 16px;
    border-bottom:1px solid rgba(255,255,255,.14);
    display:flex;
    align-items:center;
    gap:12px;
    background:linear-gradient(180deg,#090909,#000);
}
.brand-logo{
    width:58px;
    height:58px;
    min-width:58px;
    border-radius:18px;
    object-fit:cover;
    border:2px solid var(--waf-primary);
    background:#000;
    box-shadow:0 10px 26px rgba(255,215,0,.18);
}
.brand strong{
    display:block;
    color:#fff;
    font-size:15px;
    letter-spacing:.02em;
    line-height:1.15;
}
.brand small{
    display:block;
    color:var(--waf-primary);
    font-size:11px;
    margin-top:3px;
    text-transform:uppercase;
    letter-spacing:.08em;
    font-weight:800;
}
.topbar-title{
    display:flex;
    align-items:center;
    gap:12px;
    min-width:0;
}
.topbar-logo{
    width:48px;
    height:48px;
    min-width:48px;
    border-radius:14px;
    object-fit:cover;
    border:2px solid var(--waf-primary);
    background:#fff;
    box-shadow:0 8px 20px rgba(0,0,0,.08);
}
.topbar-title h1{
    margin:0;
    line-height:1.1;
}
.topbar-title span{
    color:var(--waf-muted);
    font-size:12px;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:.08em;
}

.detail-actions{
    justify-content:flex-end;
}
.detail-pro-card{
    position:relative;
    overflow:hidden;
    background:linear-gradient(180deg,#fff,#fffdf0);
    border:1px solid #e6d47a;
    border-radius:26px;
    box-shadow:0 18px 45px rgba(0,0,0,.08);
    margin-bottom:22px;
}
.detail-pro-header{
    position:relative;
    z-index:1;
    display:grid;
    grid-template-columns:auto 1fr auto;
    gap:18px;
    align-items:center;
    padding:22px;
    background:linear-gradient(135deg,#000 0%,#171717 62%,#3b3000 100%);
    color:#fff;
    border-bottom:5px solid var(--waf-primary);
}
.detail-brand-mark{
    width:98px;
    height:98px;
    border-radius:24px;
    background:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    border:2px solid var(--waf-primary);
    overflow:hidden;
    box-shadow:0 14px 34px rgba(255,215,0,.18);
}
.detail-brand-mark img{
    width:100%;
    height:100%;
    object-fit:cover;
}
.detail-identity{
    display:flex;
    align-items:center;
    gap:16px;
    min-width:0;
}
.detail-avatar-pro{
    width:92px!important;
    height:92px!important;
    min-width:92px!important;
    max-width:92px!important;
    max-height:92px!important;
    border-radius:50%!important;
    object-fit:cover!important;
    border:4px solid var(--waf-primary)!important;
    background:#fff!important;
    box-shadow:0 14px 28px rgba(0,0,0,.28);
}
.detail-avatar-empty{
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    color:#000!important;
    background:linear-gradient(135deg,#fff8b8,#FFD700)!important;
    font-weight:1000!important;
    letter-spacing:.06em!important;
    font-size:24px!important;
}
.detail-kicker{
    display:inline-flex;
    align-items:center;
    gap:6px;
    color:var(--waf-primary);
    font-size:12px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.12em;
    margin-bottom:7px;
}
.detail-kicker:before{
    content:"";
    width:28px;
    height:3px;
    border-radius:99px;
    background:var(--waf-primary);
}
.detail-identity h2{
    margin:0;
    color:#fff;
    font-size:clamp(24px,3vw,36px);
    line-height:1.1;
    letter-spacing:-.03em;
}
.detail-identity p{
    margin:8px 0 0;
    color:#e8e8e8;
    font-size:13px;
    line-height:1.45;
    font-weight:600;
}
.detail-status{
    justify-self:end;
    min-width:90px;
    text-align:center;
    background:var(--waf-primary)!important;
    color:#000!important;
    border:1px solid rgba(255,255,255,.26);
    font-weight:1000;
    text-transform:uppercase;
    letter-spacing:.04em;
    padding:8px 12px;
}
.detail-watermark{
    position:absolute;
    right:26px;
    bottom:8px;
    color:rgba(0,0,0,.035);
    font-size:110px;
    font-weight:1000;
    letter-spacing:-.08em;
    pointer-events:none;
    z-index:0;
}
.detail-section-title{
    position:relative;
    z-index:1;
    display:flex;
    align-items:center;
    gap:10px;
    padding:18px 22px 0;
    color:#000;
}
.detail-section-title span{
    width:38px;
    height:5px;
    border-radius:99px;
    background:var(--waf-primary);
    box-shadow:0 5px 12px rgba(255,215,0,.35);
}
.detail-section-title strong{
    text-transform:uppercase;
    letter-spacing:.08em;
    font-size:13px;
}
.detail-grid-pro{
    position:relative;
    z-index:1;
    padding:18px 22px 24px;
    grid-template-columns:repeat(auto-fit,minmax(255px,1fr));
}
.detail-item-pro{
    background:rgba(255,255,255,.88);
    border:1px solid #eadb8a;
    border-radius:18px;
    padding:14px 15px;
    box-shadow:0 8px 20px rgba(0,0,0,.035);
    transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.detail-item-pro:hover{
    transform:translateY(-2px);
    border-color:var(--waf-primary);
    box-shadow:0 14px 26px rgba(0,0,0,.075);
}
.detail-item-pro span{
    color:#6f5d00;
    font-size:11px;
    font-weight:1000;
    letter-spacing:.09em;
}
.detail-item-pro strong{
    color:#111;
    font-size:15px;
    line-height:1.45;
}
.detail-item-pro em{
    color:#777;
}
.detail-item-pro .detail-photo{
    width:118px!important;
    height:118px!important;
    border-radius:20px!important;
    border:3px solid var(--waf-primary)!important;
    box-shadow:0 10px 20px rgba(0,0,0,.08);
}

@media(max-width:950px){
    .detail-pro-header{
        grid-template-columns:1fr;
        text-align:left;
    }
    .detail-brand-mark{
        width:78px;
        height:78px;
    }
    .detail-status{
        justify-self:start;
    }
}
@media(max-width:650px){
    .detail-identity{
        align-items:flex-start;
        flex-direction:column;
    }
    .detail-avatar-pro{
        width:78px!important;
        height:78px!important;
        min-width:78px!important;
    }
    .detail-pro-header,
    .detail-grid-pro{
        padding-left:16px;
        padding-right:16px;
    }
    .topbar-title span{display:none}
}

/* Correctif 008 : présence DRH professionnelle avec sélection multiple */
.attendance-toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:10px 0 16px}
.attendance-mode-card{border:1px solid var(--waf-border);border-radius:18px;padding:14px;background:#fff;box-shadow:0 4px 14px rgba(0,0,0,.04)}
.attendance-mode-card label{display:flex;align-items:center;gap:8px;font-weight:800;cursor:pointer;margin:6px 0;color:#111}
.attendance-mode-card input[type="radio"],.employee-check input[type="checkbox"]{accent-color:var(--waf-primary);width:16px;height:16px}
.employee-select-panel{border:1px solid #e5e5e5;border-radius:18px;background:linear-gradient(180deg,#fff,#fffdf1);overflow:hidden}
.employee-select-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;background:#000;color:var(--waf-primary);font-weight:900}
.employee-select-actions{display:flex;gap:8px;flex-wrap:wrap}
.employee-select-actions button{border:1px solid var(--waf-primary);background:transparent;color:var(--waf-primary);padding:6px 9px;border-radius:10px;font-weight:800;cursor:pointer}
.employee-search-box{padding:12px 14px;border-bottom:1px solid #eee;background:#fff}
.employee-search-box input{width:100%;padding:11px;border:1px solid var(--waf-border);border-radius:12px}
.employee-check-list{max-height:360px;overflow:auto;padding:10px;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:8px}
.employee-check{display:flex;gap:10px;align-items:center;border:1px solid #eee;background:#fff;border-radius:14px;padding:10px;cursor:pointer;transition:.16s ease}
.employee-check:hover{border-color:var(--waf-primary);box-shadow:0 8px 20px rgba(0,0,0,.08);transform:translateY(-1px)}
.employee-check strong{display:block;font-size:14px;color:#111}.employee-check small{display:block;color:#555;font-weight:700}.attendance-hidden{display:none!important}.attendance-summary{font-size:13px;color:#444;font-weight:800}.attendance-present-all{background:#fffbe6;border:1px solid var(--waf-primary);border-radius:14px;padding:12px;color:#111;font-weight:800}
