:root{
    --pnb-green:#f8a0a5;
    --pnb-green-dark:#6f2b3a;
    --pnb-red:#f58a91;
    --pnb-yellow:#ffd1d4;
    --pnb-ink:#6f2b3a;
    --pnb-muted:#7b4650;
    --pnb-line:#ffd9dc;
    --pnb-soft:#fffdfd;
    --pnb-white:#ffffff;
    --pnb-shadow:0 18px 48px rgba(111,43,58,.07);
    --sarc-blue:#6f2b3a;
    --sarc-blue-mid:#f58a91;
    --sarc-blue-light:#f8a0a5;
    --sarc-blue-dark:#6f2b3a;
    --sarc-green:#f8a0a5;
    --sarc-green-soft:#fffdfd;
    --sarc-steel:#fff8f9;
    --sarc-glass:rgba(255,255,255,.82);
}

*{
    box-sizing:border-box;
}

body{
    background:
        radial-gradient(circle at 18% 12%,rgba(248,160,165,.06),transparent 28%),
        radial-gradient(circle at 80% 16%,rgba(111,43,58,.07),transparent 30%),
        linear-gradient(145deg,#ffffff 0%,#fffdfd 48%,#ffffff 100%) !important;
    color:var(--pnb-ink) !important;
    font-family:Arial,Helvetica,sans-serif !important;
    margin:0 !important;
}

.pnb-app-header{
    position:relative;
    z-index:30000;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    padding:9px 24px;
    background:
        linear-gradient(120deg,rgba(111,43,58,.98),rgba(111,43,58,.96) 58%,rgba(245,138,145,.90)),
        var(--sarc-blue-dark);
    color:white;
    border-bottom:4px solid rgba(255,255,255,.90);
    box-shadow:0 14px 30px rgba(111,43,58,.24);
    overflow:visible;
}

.pnb-brand{
    display:flex;
    align-items:center;
    gap:14px;
    min-width:0;
}

.pnb-logo{
    width:clamp(54px,4.6vw,74px);
    height:clamp(54px,4.6vw,74px);
    object-fit:contain;
    background:white;
    border-radius:13px;
    padding:5px;
    box-shadow:0 10px 22px rgba(111,43,58,.26);
}

.pnb-title{
    display:flex;
    flex-direction:column;
    gap:2px;
    min-width:0;
}

.pnb-title strong{
    font-size:19px;
    letter-spacing:0;
    white-space:normal;
}

.pnb-title span{
    font-size:12px;
    opacity:.9;
}

.pnb-chip{
    position:relative;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:clamp(122px,11vw,174px);
    min-height:clamp(40px,3.4vw,50px);
    overflow:hidden;
    background:
        linear-gradient(120deg,rgba(255,255,255,.32),rgba(248,160,165,.30),rgba(255,255,255,.16));
    border:1px solid rgba(255,255,255,.55);
    border-radius:999px;
    padding:8px 18px;
    color:rgba(255,255,255,.96);
    font-size:clamp(18px,1.6vw,26px);
    font-weight:900;
    letter-spacing:1px;
    text-align:center;
    text-shadow:0 2px 10px rgba(111,43,58,.07);
    white-space:nowrap;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.36),
        0 12px 30px rgba(111,43,58,.07);
    animation:pnbChipGlow 5s ease-in-out infinite;
}

.pnb-chip::before{
    content:"";
    position:absolute;
    inset:-40% -80%;
    background:linear-gradient(115deg,transparent 35%,rgba(255,255,255,.45) 50%,transparent 65%);
    transform:translateX(-35%);
    animation:pnbChipSweep 4.5s ease-in-out infinite;
    pointer-events:none;
}

.sarc-header-actions{
    position:relative;
    z-index:30010;
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:14px;
    margin-left:auto;
}

.sarc-user-menu{
    position:relative;
    z-index:30020;
}

.sarc-user-menu summary{
    min-height:50px;
    display:flex;
    align-items:center;
    gap:10px;
    padding:9px 16px 9px 10px;
    border:1px solid rgba(255,255,255,.42);
    border-radius:999px;
    background:rgba(255,255,255,.14);
    color:#fff;
    cursor:pointer;
    list-style:none;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 12px 28px rgba(111,43,58,.07);
}

.sarc-user-menu summary::-webkit-details-marker{
    display:none;
}

.sarc-user-avatar{
    width:34px;
    height:34px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    background:linear-gradient(135deg,#fff,#fffdfd);
    color:var(--sarc-blue);
    font-weight:900;
    box-shadow:0 8px 18px rgba(111,43,58,.22);
}

.sarc-user-name{
    max-width:220px;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    font-size:14px;
    font-weight:900;
}

.sarc-user-panel{
    position:fixed;
    right:24px;
    top:86px;
    width:280px;
    display:none;
    gap:9px;
    padding:14px;
    border:1px solid rgba(255,255,255,.62);
    border-radius:16px;
    background:rgba(255,255,255,.94);
    color:var(--sarc-blue);
    box-shadow:0 24px 58px rgba(111,43,58,.25);
    backdrop-filter:blur(16px);
    z-index:30030;
    pointer-events:auto;
}

.sarc-user-menu[open] .sarc-user-panel{
    display:grid;
}

.sarc-user-panel strong{
    padding:7px 10px;
    border-radius:10px;
    background:rgba(111,43,58,.07);
    color:var(--sarc-blue);
    font-size:12px;
    letter-spacing:.08em;
}

.sarc-user-panel a{
    display:flex;
    align-items:center;
    min-height:48px;
    padding:12px 14px;
    border-radius:12px;
    color:var(--sarc-blue) !important;
    text-decoration:none;
    font-weight:900;
    font-size:15px;
}

.sarc-user-panel a:hover{
    background:rgba(111,43,58,.07);
}


.sarc-3d-stage{
    position:fixed;
    inset:0;
    z-index:0;
    pointer-events:none;
    overflow:hidden;
    perspective:1200px;
}

.sarc-3d-stage::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        linear-gradient(120deg,rgba(111,43,58,.07),transparent 46%),
        radial-gradient(circle at 78% 18%,rgba(255,255,255,.34),transparent 28%),
        radial-gradient(circle at 18% 76%,rgba(111,43,58,.07),transparent 34%);
}

.sarc-3d-orbit{
    position:absolute;
    right:clamp(-160px,4vw,70px);
    top:clamp(110px,16vh,190px);
    width:clamp(330px,42vw,660px);
    aspect-ratio:1;
    transform-style:preserve-3d;
    animation:sarcFloat 13s ease-in-out infinite;
    opacity:.46;
}

.sarc-3d-mark{
    position:absolute;
    inset:11%;
    transform-style:preserve-3d;
    animation:sarcSpin 22s linear infinite;
}

.sarc-prism{
    position:absolute;
    width:44%;
    aspect-ratio:1;
    clip-path:polygon(50% 0,100% 100%,0 100%);
    background:
        linear-gradient(145deg,rgba(255,255,255,.18),transparent 36%),
        linear-gradient(180deg,#f58a91,#6f2b3a);
    box-shadow:
        inset 0 0 0 2px rgba(255,255,255,.18),
        0 30px 70px rgba(111,43,58,.32);
}

.sarc-prism::after{
    content:"";
    position:absolute;
    inset:17%;
    clip-path:polygon(50% 0,100% 100%,0 100%);
    background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(248,160,165,.06));
    opacity:.64;
}

.sarc-prism-left{
    left:3%;
    bottom:13%;
    transform:rotateX(58deg) rotateZ(180deg) translateZ(64px);
}

.sarc-prism-top{
    left:28%;
    top:2%;
    transform:rotateX(58deg) rotateZ(0deg) translateZ(116px);
}

.sarc-prism-right{
    right:3%;
    bottom:13%;
    transform:rotateX(58deg) rotateZ(180deg) translateZ(40px);
}

.sarc-recycle-ring{
    position:absolute;
    left:36%;
    top:23%;
    width:28%;
    aspect-ratio:1;
    border:clamp(8px,1vw,14px) solid rgba(255,255,255,.84);
    border-radius:28%;
    transform:rotateX(58deg) translateZ(150px);
    box-shadow:0 0 34px rgba(248,160,165,.50);
}

.sarc-core{
    position:absolute;
    left:29%;
    top:31%;
    width:42%;
    aspect-ratio:1;
    border-radius:26%;
    transform:rotateX(58deg) translateZ(184px);
    background:
        linear-gradient(145deg,rgba(255,255,255,.96),rgba(255,248,249,.70)),
        linear-gradient(135deg,rgba(111,43,58,.07),transparent);
    box-shadow:
        inset 0 0 0 2px rgba(255,255,255,.90),
        0 22px 48px rgba(111,43,58,.26);
}

.sarc-core::before{
    content:"OCB";
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    color:rgba(111,43,58,.90);
    font-size:clamp(22px,3vw,48px);
    font-weight:900;
    letter-spacing:0;
}

.sarc-beam,
.sarc-spark{
    position:absolute;
    display:block;
}

.sarc-beam{
    height:12px;
    border-radius:999px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.72),rgba(248,160,165,.52),transparent);
    filter:blur(.2px);
}

.sarc-beam-a{left:0;right:8%;top:68%;transform:rotate(-12deg) translateZ(20px);}
.sarc-beam-b{left:18%;right:0;top:41%;transform:rotate(18deg) translateZ(60px);}
.sarc-beam-c{left:9%;right:20%;top:82%;transform:rotate(8deg) translateZ(10px);}

.sarc-spark{
    width:12px;
    height:12px;
    border-radius:50%;
    background:#fff;
    box-shadow:0 0 22px rgba(248,160,165,.85);
    animation:sarcSpark 4.8s ease-in-out infinite;
}

.sarc-spark-a{left:18%;top:31%;}
.sarc-spark-b{right:21%;top:63%;animation-delay:1.3s;}
.sarc-spark-c{left:50%;bottom:10%;animation-delay:2.5s;}

body > *:not(.sarc-3d-stage){
    position:relative;
    z-index:1;
}

main,
.container,
.dashboard-container,
.section-shell,
.login-shell,
.portal-shell{
    position:relative;
    z-index:2;
}

.card,
.panel,
.profile,
.quick,
.metric,
.module-panel,
.password-card,
.login-card,
.portal-card,
.rh-group,
.rh-direct,
.commande-group,
.notice,
.page{
    border:1px solid rgba(255,255,255,.66) !important;
    background:
        linear-gradient(145deg,rgba(255,255,255,.94),rgba(255,248,249,.78)) !important;
    backdrop-filter:blur(18px);
    box-shadow:
        0 22px 55px rgba(111,43,58,.07),
        inset 0 1px 0 rgba(255,255,255,.70) !important;
}

h1,
h2,
h3,
.section-title,
.portal-card h2,
.rh-group summary,
.rh-direct{
    color:var(--sarc-blue) !important;
}

button,
.btn,
.task-link,
.print-btn,
.back-btn{
    border-radius:10px !important;
    background:linear-gradient(135deg,var(--sarc-blue),var(--sarc-blue-mid)) !important;
    box-shadow:0 12px 24px rgba(111,43,58,.22);
}

table th,
th{
    background:linear-gradient(135deg,var(--sarc-blue),var(--sarc-blue-mid)) !important;
}

a,
.back-link,
.back-commandes,
.statut,
.ptba-category,
.ptba-quarter{
    color:var(--sarc-blue) !important;
}

.rh-submenu a,
.commande-submenu a,
.multi-dropdown-option:hover{
    background:rgba(248,160,165,.07) !important;
    color:var(--sarc-blue) !important;
}

.rh-group[open] summary,
.rh-direct:hover,
.commande-group[open] summary{
    background:linear-gradient(135deg,rgba(111,43,58,.07),rgba(248,160,165,.07)) !important;
    box-shadow:inset 0 -4px 0 rgba(111,43,58,.72) !important;
}

body.login-page{
    background:
        radial-gradient(circle at 76% 20%,rgba(248,160,165,.24),transparent 28%),
        linear-gradient(145deg,#fffdfd,#ffffff) !important;
}

.login-background{
    background:
        linear-gradient(120deg,rgba(111,43,58,.72),rgba(111,43,58,.30),rgba(255,255,255,.26)),
        url('/images/ocase-bebe-bg.png') center/cover no-repeat !important;
    filter:saturate(.9) contrast(1.04) !important;
}

.login-background::after{
    background:linear-gradient(90deg,rgba(255,250,250,.82),rgba(255,250,250,.50),rgba(255,250,250,.24)) !important;
}

.login-card{
    transform:translateZ(0);
    border-radius:28px !important;
}

.login-card h1{
    font-size:clamp(42px,5vw,74px) !important;
    letter-spacing:0;
}

.senegal-flag{
    height:14px !important;
    border-radius:999px !important;
    overflow:hidden;
    box-shadow:0 10px 22px rgba(111,43,58,.07);
}

.senegal-flag span:nth-child(1),
.senegal-flag span:nth-child(2),
.senegal-flag span:nth-child(3){
    background:linear-gradient(90deg,var(--sarc-blue),#fff,var(--sarc-blue-mid)) !important;
}

.portal-page,
.portal-background,
body:not(.login-page){
    background-color:#fffdfd !important;
}

.portal-background{
    filter:none !important;
    opacity:.72;
}

.portal-watermark strong,
.login-watermark strong{
    color:rgba(111,43,58,.07) !important;
}

.portal-watermark span,
.login-watermark span{
    color:rgba(111,43,58,.40) !important;
}

@keyframes sarcFloat{
    0%,100%{transform:translate3d(0,0,0) rotateX(54deg) rotateZ(-7deg);}
    50%{transform:translate3d(-18px,22px,60px) rotateX(60deg) rotateZ(5deg);}
}

@keyframes sarcSpin{
    from{transform:rotateY(0deg) rotateZ(-8deg);}
    to{transform:rotateY(360deg) rotateZ(-8deg);}
}

@keyframes sarcSpark{
    0%,100%{transform:translate3d(0,0,0) scale(.75);opacity:.45;}
    50%{transform:translate3d(16px,-18px,70px) scale(1.25);opacity:1;}
}

@media(max-width:780px){
    .sarc-3d-orbit{
        right:-210px;
        top:140px;
        width:430px;
        opacity:.30;
    }

    .pnb-app-header{
        padding:9px 12px;
        align-items:flex-start;
    }

    .sarc-header-actions{
        flex-direction:column;
        align-items:flex-end;
        gap:8px;
    }

    .sarc-user-name{
        display:none;
    }
}

.pnb-notification-badge{
    position:absolute;
    top:4px;
    right:4px;
    min-width:20px;
    height:20px;
    padding:0 6px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    background:#f58a91;
    color:#fff;
    font-size:12px;
    font-weight:900;
    line-height:1;
    box-shadow:0 2px 8px rgba(245,138,145,.35);
    border:2px solid #fff;
    z-index:5;
}

.pnb-quick-links a,
.pnb-menu-parent,
[data-notification-key]{
    position:relative;
}

.pnb-archives-block{
    margin-top:18px;
    border:1px solid rgba(111,43,58,.07);
    border-radius:8px;
    background:#fff;
    box-shadow:0 8px 22px rgba(111,43,58,.07);
    overflow:hidden;
}

.pnb-archives-toggle{
    width:100%;
    border:0;
    background:#fffdfd;
    color:#6f2b3a;
    padding:13px 16px;
    text-align:left;
    font-weight:800;
    cursor:pointer;
}

.pnb-archives-toggle::after{
    content:"";
    float:right;
    width:9px;
    height:9px;
    border-right:2px solid currentColor;
    border-bottom:2px solid currentColor;
    transform:rotate(45deg);
    margin-top:3px;
    transition:transform .18s ease;
}

.pnb-archives-block.is-open .pnb-archives-toggle::after{
    transform:rotate(225deg);
    margin-top:8px;
}

.pnb-archives-content{
    display:none;
    padding:12px;
    overflow-x:auto;
}

.pnb-archives-block.is-open .pnb-archives-content{
    display:block;
}

.pnb-target-row{
    outline:3px solid rgba(248,160,165,.95);
    outline-offset:-3px;
    background:#fffdfd !important;
    transition:background .25s ease, outline-color .25s ease;
}

.pnb-row-unread{
    background:#fffdfd !important;
}

.observation{
    position:relative;
    cursor:default;
}

.observation[data-preview]:hover{
    z-index:60;
    box-shadow:0 8px 22px rgba(111,43,58,.07);
}

.observation[data-preview]:hover::after{
    content:none;
}

.pnb-floating-preview{
    position:fixed;
    max-width:min(360px,calc(100vw - 28px));
    max-height:min(220px,calc(100vh - 28px));
    overflow:auto;
    white-space:pre-wrap;
    background:rgba(255,255,255,.98);
    color:#6f2b3a;
    border:1px solid #ffd9dc;
    border-left:5px solid #f8a0a5;
    border-radius:8px;
    box-shadow:0 18px 38px rgba(111,43,58,.24);
    padding:10px 12px;
    font-size:11px;
    line-height:1.42;
    font-weight:700;
    z-index:10000;
    pointer-events:none;
}

.pnb-observation-poste,
.pnb-observation-date{
    display:block;
    color:#7b4650;
    font-weight:700;
    line-height:1.2;
}

.pnb-observation-poste{
    margin-top:2px;
    font-size:10px;
}

.pnb-observation-date{
    margin-top:1px;
    font-size:9px;
    opacity:.72;
}

.observation.observation-unread{
    background:#fffdfd !important;
    border-left-color:#f58a91 !important;
    box-shadow:0 0 0 2px rgba(245,138,145,.08);
}

.observation.observation-unread::before{
    content:"";
    width:10px;
    height:10px;
    display:inline-block;
    border-radius:999px;
    background:#f58a91;
    box-shadow:0 0 0 3px rgba(245,138,145,.15);
    margin-right:7px;
    vertical-align:middle;
}

.pnb-row-unread-dot,
.thread-unread-dot{
    width:12px;
    height:12px;
    display:inline-flex;
    flex:0 0 auto;
    border-radius:999px;
    background:#f58a91;
    box-shadow:0 0 0 3px rgba(245,138,145,.16);
}

.pnb-row-unread-dot{
    margin-right:8px;
    vertical-align:middle;
}

.thread-item.has-unread{
    font-weight:900;
}

.thread-unread-count{
    min-width:22px;
    height:22px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    background:#f58a91;
    color:#fff !important;
    font-size:12px;
    font-weight:900;
}

@keyframes pnbChipGlow{
    0%,100%{
        border-color:rgba(255,255,255,.45);
        box-shadow:inset 0 1px 0 rgba(255,255,255,.32),0 12px 30px rgba(111,43,58,.07);
    }
    50%{
        border-color:rgba(248,160,165,.78);
        box-shadow:inset 0 1px 0 rgba(255,255,255,.42),0 14px 34px rgba(248,160,165,.06);
    }
}

@keyframes pnbChipSweep{
    0%,35%{
        transform:translateX(-35%);
    }
    70%,100%{
        transform:translateX(35%);
    }
}

.pnb-profile-menu{
    position:relative;
    display:inline-flex;
    align-items:center;
}

.pnb-user-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    min-height:42px;
    padding:9px 14px;
    border:1px solid rgba(255,255,255,.42);
    border-radius:999px;
    background:white;
    color:var(--pnb-green-dark);
    font-size:14px;
    font-weight:800;
    box-shadow:0 10px 24px rgba(111,43,58,.07);
    white-space:nowrap;
    cursor:pointer;
}

.pnb-profile-dropdown{
    position:absolute;
    top:calc(100% + 8px);
    right:0;
    z-index:90;
    min-width:230px;
    padding:7px;
    background:white;
    border:1px solid rgba(111,43,58,.07);
    border-radius:8px;
    box-shadow:0 16px 34px rgba(111,43,58,.07);
    opacity:0;
    pointer-events:none;
    transform:translateY(6px);
    transition:opacity .18s ease, transform .18s ease;
}

.pnb-profile-link{
    display:block;
    padding:11px 12px;
    color:#6f2b3a;
    border-radius:6px;
    font-size:14px;
    font-weight:800;
    text-decoration:none;
}

.pnb-profile-link:hover{
    background:#fffdfd;
}

.pnb-profile-link.is-danger{
    color:#6f2b3a;
}

.pnb-profile-menu:hover .pnb-profile-dropdown,
.pnb-profile-menu:focus-within .pnb-profile-dropdown,
.pnb-profile-menu.is-open .pnb-profile-dropdown{
    opacity:1;
    pointer-events:auto;
    transform:translateY(0);
}

.pnb-quick-access{
    position:sticky;
    top:0;
    z-index:40;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    width:100%;
    margin:0 auto 18px;
    padding:0 clamp(16px,2.2vw,42px);
    min-height:clamp(66px,5.4vw,86px);
    background:rgba(255,255,255,.96);
    border-bottom:1px solid rgba(111,43,58,.07);
    box-shadow:0 14px 30px rgba(111,43,58,.07);
    backdrop-filter:blur(12px);
    animation:pnbMenuDrop .45s ease both;
    overflow:visible;
}

.pnb-quick-access h2{
    position:absolute;
    width:1px;
    height:1px;
    margin:-1px !important;
    padding:0 !important;
    overflow:hidden;
    clip:rect(0 0 0 0);
    white-space:nowrap;
}

.pnb-quick-access h2::after{
    display:none;
}

.pnb-quick-links{
    flex:1 1 auto;
    min-width:0;
    display:flex;
    align-items:center;
    justify-content:space-between;
    flex-wrap:nowrap;
    gap:clamp(2px,.35vw,9px);
    width:100%;
}

.pnb-module-menu .pnb-quick-links{
    justify-content:center;
    gap:clamp(24px,6vw,96px);
}

.pnb-quick-links a,
.pnb-menu-parent{
    position:relative;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:clamp(48px,4vw,62px);
    padding:0 clamp(7px,.78vw,16px);
    background:transparent !important;
    color:#6f2b3a !important;
    border-radius:0 !important;
    font-size:var(--pnb-menu-font-size, clamp(11px,.72vw,16px));
    font-weight:800;
    text-decoration:none !important;
    text-transform:uppercase;
    box-shadow:none !important;
    overflow:visible;
    white-space:nowrap;
    transition:
        color .25s ease,
        transform .25s ease,
        background-color .25s ease;
}

.pnb-quick-links > a.is-icon-menu,
.pnb-menu-parent.is-icon-menu{
    width:clamp(46px,4.6vw,66px);
    padding:0;
}

.pnb-menu-icon{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:clamp(22px,2vw,30px);
    height:clamp(22px,2vw,30px);
    color:currentColor;
}

.pnb-menu-icon svg{
    width:100%;
    height:100%;
    stroke:currentColor;
    fill:none;
    stroke-width:2;
    stroke-linecap:round;
    stroke-linejoin:round;
}

.pnb-menu-label{
    display:inline-block;
}

.is-icon-menu > .pnb-menu-label{
    position:absolute;
    left:50%;
    top:calc(100% + 9px);
    z-index:8;
    min-width:max-content;
    padding:10px 16px;
    background:#6f2b3a;
    color:white;
    border-radius:6px;
    font-size:clamp(18px,1.35vw,24px);
    font-weight:700;
    line-height:1;
    text-transform:none;
    box-shadow:0 10px 24px rgba(111,43,58,.07);
    opacity:0;
    pointer-events:none;
    transform:translateX(-50%) translateY(6px);
    transition:opacity .18s ease, transform .18s ease;
}

.is-icon-menu:hover > .pnb-menu-label,
.is-icon-menu:focus > .pnb-menu-label,
.is-icon-menu:focus-within > .pnb-menu-label{
    opacity:1;
    transform:translateX(-50%) translateY(0);
}

.pnb-menu-parent{
    border:0;
    cursor:pointer;
}

.pnb-menu-chevron{
    display:inline-block;
    margin-left:4px;
    font-size:11px;
    transition:transform .25s ease;
}

.pnb-menu-group{
    position:relative;
    display:inline-flex;
    flex:0 1 auto;
    min-width:0;
    overflow:visible;
}

.pnb-submenu{
    position:absolute;
    top:calc(100% + 58px);
    left:50%;
    min-width:260px;
    z-index:7;
    padding:8px 0;
    background:white;
    border:1px solid rgba(111,43,58,.07);
    border-radius:8px;
    box-shadow:0 20px 42px rgba(111,43,58,.07);
    opacity:0;
    pointer-events:none;
    transform:translateX(-50%) translateY(10px);
    transition:opacity .22s ease, transform .22s ease;
}

.pnb-menu-group .pnb-menu-label{
    top:calc(100% + 8px);
    z-index:12;
    padding:10px 18px;
    background:white;
    color:var(--pnb-green-dark);
    border:1px solid rgba(111,43,58,.07);
    box-shadow:0 12px 24px rgba(111,43,58,.07);
    font-size:clamp(20px,1.5vw,28px);
    font-weight:800;
    text-transform:none;
}

.pnb-menu-group:hover .pnb-menu-label,
.pnb-menu-group:focus-within .pnb-menu-label,
.pnb-menu-group.is-expanded .pnb-menu-label{
    opacity:1;
    transform:translateX(-50%) translateY(0);
}

.pnb-submenu::before{
    content:"";
    position:absolute;
    top:-58px;
    left:0;
    right:0;
    height:58px;
}

.pnb-submenu a{
    display:flex;
    justify-content:flex-start;
    width:100%;
    min-height:48px;
    padding:0 18px;
    color:#6f2b3a !important;
    text-transform:none;
    font-size:15px;
    border-bottom:1px solid rgba(111,43,58,.07);
}

.pnb-submenu a:last-child{
    border-bottom:0;
}

.pnb-menu-group:hover .pnb-submenu,
.pnb-menu-group:focus-within .pnb-submenu,
.pnb-menu-group.is-expanded .pnb-submenu{
    opacity:1;
    pointer-events:auto;
    transform:translateX(-50%) translateY(0);
}

.pnb-menu-group:hover .pnb-menu-chevron,
.pnb-menu-group:focus-within .pnb-menu-chevron,
.pnb-menu-group.is-expanded .pnb-menu-chevron{
    transform:rotate(180deg);
}

.pnb-quick-links a::before,
.pnb-menu-parent::before{
    content:"";
    position:absolute;
    left:14px;
    right:14px;
    bottom:8px;
    height:3px;
    background:linear-gradient(90deg,var(--pnb-green),var(--pnb-yellow));
    border-radius:999px;
    transform:scaleX(0);
    transform-origin:left center;
    transition:transform .28s ease;
}

.pnb-quick-links a::after,
.pnb-menu-parent::after{
    content:"";
    position:absolute;
    left:50%;
    bottom:-18px;
    width:64%;
    height:18px;
    background:rgba(248,160,165,.06);
    border-radius:50%;
    opacity:0;
    transform:translateX(-50%) scale(.65);
    transition:opacity .25s ease, transform .25s ease;
}

.pnb-quick-links a:hover,
.pnb-quick-links a.active,
.pnb-menu-parent:hover,
.pnb-menu-parent.active{
    color:var(--pnb-green) !important;
    background:linear-gradient(180deg,rgba(111,43,58,.07),rgba(248,160,165,.07)) !important;
    border-radius:14px !important;
    transform:translateY(-2px);
}

.pnb-quick-links a:hover::before,
.pnb-quick-links a.active::before,
.pnb-menu-parent:hover::before,
.pnb-menu-parent.active::before{
    transform:scaleX(1);
}

.pnb-quick-links a:hover::after,
.pnb-quick-links a.active::after,
.pnb-menu-parent:hover::after,
.pnb-menu-parent.active::after{
    opacity:1;
    transform:translateX(-50%) scale(1);
}

.pnb-quick-links a.danger{
    color:#7b4650 !important;
}

.pnb-quick-links a.danger:hover,
.pnb-quick-links a.danger.active{
    color:var(--pnb-red) !important;
}

.pnb-menu-toggle{
    display:none;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:0 14px;
    background:var(--pnb-green) !important;
    color:white !important;
    border-radius:6px !important;
}

.pnb-chat-widget{
    position:fixed;
    left:auto !important;
    right:24px !important;
    bottom:18px;
    z-index:30120;
    width:min(390px,calc(100vw - 32px));
    background:white;
    border:1px solid rgba(111,43,58,.07);
    border-radius:12px;
    box-shadow:0 20px 52px rgba(111,43,58,.26);
    overflow:hidden;
}

.pnb-chat-widget.is-open{
    width:min(390px,calc(100vw - 32px));
    max-height:calc(100vh - 42px);
}

.pnb-chat-header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    width:100%;
    min-height:54px;
    background:linear-gradient(90deg,#6f2b3a,var(--pnb-green-dark));
    color:white;
}

.pnb-chat-title,
.pnb-chat-open-module,
.pnb-chat-expand,
.pnb-chat-collapse,
.pnb-chat-hide{
    background:transparent !important;
    color:white !important;
    border:0;
    border-radius:0 !important;
    box-shadow:none !important;
    margin:0;
    padding:0 10px;
    min-height:54px;
    cursor:pointer;
}

.pnb-chat-open-module{
    flex:0 0 38px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:54px;
    font-size:22px;
    font-weight:900;
    line-height:1;
    text-decoration:none;
    opacity:.95;
}

.pnb-chat-open-module:hover{
    background:rgba(255,255,255,.14) !important;
    opacity:1;
}

.pnb-chat-title{
    flex:1;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    text-align:left;
    position:relative;
}

.pnb-chat-expand,
.pnb-chat-collapse{
    flex:0 0 auto;
    font-size:11px;
    font-weight:700;
    opacity:.9;
}

.pnb-chat-widget.is-open .pnb-chat-expand{
    display:none;
}

.pnb-chat-widget:not(.is-open) .pnb-chat-collapse{
    display:none;
}

.pnb-chat-hide{
    flex:0 0 32px;
    font-size:16px;
}

.pnb-chat-title strong{
    font-size:16px;
}

.pnb-chat-current{
    display:none;
    max-width:120px;
    overflow:hidden;
    color:rgba(255,255,255,.86);
    font-size:11px;
    font-weight:700;
    line-height:1;
    text-overflow:ellipsis;
    white-space:nowrap;
}

.pnb-chat-unread-badge{
    display:none;
    min-width:18px;
    height:18px;
    padding:0 5px;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    background:#f58a91;
    color:white !important;
    font-size:10px;
    font-weight:900;
    line-height:18px;
}

.pnb-chat-unread-badge.is-visible{
    display:inline-flex;
}

.pnb-chat-widget.is-open .pnb-chat-title .pnb-chat-unread-badge{
    display:none;
}

.pnb-chat-body{
    display:none;
    padding:0;
    background:#fffdfd;
}

.pnb-chat-widget.is-open .pnb-chat-body{
    display:grid;
    grid-template-columns:1fr;
    grid-template-areas:
        "toolbar"
        "filters"
        "threads"
        "conversation"
        "form";
    max-height:calc(100vh - 104px);
}

.pnb-chat-toolbar{
    grid-area:toolbar;
    display:flex;
    align-items:center;
    gap:8px;
    padding:10px 12px;
    background:white;
    border-bottom:1px solid var(--pnb-line);
}

.pnb-chat-search{
    flex:1;
    min-width:0;
    height:38px;
    padding:0 12px;
    border:1px solid var(--pnb-line);
    border-radius:8px;
    background:#fffdfd;
    color:var(--pnb-green-dark);
    font-weight:800;
}

.pnb-chat-filters{
    grid-area:filters;
    display:flex;
    gap:0;
    padding:0 12px;
    overflow-x:auto;
    background:white;
    border-bottom:1px solid var(--pnb-line);
}

.pnb-chat-filters button{
    flex:1 1 0;
    min-height:44px;
    padding:0 6px;
    border:0 !important;
    border-bottom:3px solid transparent !important;
    border-radius:0 !important;
    background:white !important;
    color:var(--pnb-green-dark) !important;
    box-shadow:none !important;
    font-size:13px;
    font-weight:900;
}

.pnb-chat-filter-badge{
    display:none;
    min-width:20px;
    height:20px;
    margin-left:7px;
    padding:0 6px;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    background:#f58a91;
    color:white !important;
    font-size:11px;
    font-weight:950;
    line-height:20px;
    vertical-align:middle;
    box-shadow:0 0 0 5px rgba(245,138,145,.13);
}

.pnb-chat-filter-badge.is-visible{
    display:inline-flex;
}

.pnb-chat-filters button.active{
    background:white !important;
    color:var(--pnb-green-dark) !important;
    border-color:var(--pnb-green-dark) !important;
}

.pnb-chat-messages{
    grid-area:messages;
    display:flex;
    flex-direction:column;
    gap:8px;
    height:170px;
    overflow:auto;
    padding:14px;
    background:white;
}

.pnb-chat-group,
.pnb-chat-target{
    display:none;
}

.pnb-chat-threads{
    grid-area:threads;
    display:flex;
    flex-direction:column;
    gap:0;
    margin:0;
    overflow:auto;
    max-height:360px;
    padding:0;
    background:white;
    border-right:0;
    border-bottom:1px solid var(--pnb-line);
}

.pnb-chat-threads:not(.is-searching){
    min-height:72px;
    max-height:92px;
    overflow:hidden;
}

.pnb-chat-threads:not(.is-searching)::before{
    content:"Tapez un nom d'agent ou de groupe pour afficher les résultats.";
    display:flex;
    min-height:72px;
    align-items:center;
    padding:0 16px;
    color:var(--pnb-muted);
    font-size:13px;
    font-weight:800;
    line-height:1.35;
}

.pnb-chat-threads button{
    position:relative;
    flex:0 0 auto;
    display:flex;
    align-items:center;
    justify-content:flex-start;
    min-height:74px;
    max-width:none;
    width:100%;
    padding:10px 44px 10px 16px;
    overflow:hidden;
    background:white !important;
    color:var(--pnb-green-dark) !important;
    border:0 !important;
    border-bottom:1px solid var(--pnb-line) !important;
    border-radius:0 !important;
    box-shadow:none !important;
    font-size:15px;
    font-weight:900;
    text-align:left;
    text-overflow:ellipsis;
    white-space:nowrap;
}

.pnb-chat-threads button[hidden]{
    display:none !important;
}

.pnb-chat-threads button.has-unread{
    background:#fffdfd !important;
}

.pnb-chat-threads button.active,
.pnb-chat-threads button.active.has-unread{
    background:var(--pnb-green-dark) !important;
    color:white !important;
    border-left:5px solid var(--pnb-green) !important;
    padding-left:11px;
}

.thread-unread-count{
    position:absolute;
    right:12px;
    top:50%;
    transform:translateY(-50%);
    min-width:20px;
    height:20px;
    padding:0 6px;
    border-radius:999px;
    background:#f58a91;
    color:white;
    font-size:11px;
    font-weight:900;
    line-height:20px;
    text-align:center;
}

.thread-unread-dot{
    display:none;
}

.pnb-chat-conversation{
    grid-area:conversation;
    display:flex;
    flex-direction:column;
    min-width:0;
    background:white;
}

.pnb-chat-widget.is-searching .pnb-chat-conversation,
.pnb-chat-widget.is-searching .pnb-chat-form{
    display:none;
}

.pnb-chat-conversation-header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    min-height:50px;
    padding:0 16px;
    border-bottom:1px solid var(--pnb-line);
    background:white;
}

.pnb-chat-conversation-title{
    min-width:0;
    overflow:hidden;
    color:var(--pnb-green-dark);
    font-size:16px;
    text-overflow:ellipsis;
    white-space:nowrap;
}

.pnb-chat-conversation-date{
    flex:0 0 auto;
    color:var(--pnb-muted);
    font-size:12px;
    font-weight:800;
}

.pnb-chat-message{
    align-self:flex-start;
    max-width:86%;
    padding:8px 10px;
    background:white;
    border:1px solid var(--pnb-line);
    border-radius:12px 12px 12px 4px;
    font-size:13px;
}

.pnb-chat-message.unread{
    background:#fffdfd;
    border-left:5px solid #f58a91;
}

.pnb-chat-message-meta{
    display:flex;
    align-items:baseline;
    gap:5px;
    margin-bottom:3px;
    min-width:0;
}

.pnb-chat-message-meta strong{
    min-width:0;
    overflow:hidden;
    color:var(--pnb-green-dark);
    font-size:11px;
    text-overflow:ellipsis;
    white-space:nowrap;
}

.pnb-chat-message-meta span{
    flex:0 0 auto;
    color:var(--pnb-muted);
    font-size:10px;
    font-weight:800;
}

.pnb-chat-message > span{
    display:block;
}

.pnb-chat-message small{
    display:block;
    margin-top:4px;
    color:var(--pnb-muted);
    font-size:11px;
}

.pnb-chat-message.mine{
    align-self:flex-end;
    background:#fff8f9;
    border-color:rgba(248,160,165,.22);
    border-radius:12px 12px 4px 12px;
}

.pnb-chat-empty{
    color:var(--pnb-muted);
    font-size:13px;
    text-align:center;
    padding:24px 8px;
}

.pnb-chat-form{
    grid-area:form;
    display:flex;
    gap:8px;
    margin:0;
    padding:10px 12px 12px;
    background:white;
    border-top:1px solid var(--pnb-line);
}

.pnb-chat-form input{
    flex:1;
    min-width:0;
}

.pnb-chat-form button{
    flex:0 0 auto;
    margin:0;
}

.pnb-chat-module{
    flex:0 0 auto;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    margin-top:0;
    padding:8px 9px;
    border-radius:10px;
    background:white;
    color:var(--pnb-green-dark);
    font-size:11px;
    font-weight:700;
    text-align:center;
    text-decoration:none;
}

.pnb-chat-launcher{
    position:fixed;
    left:auto !important;
    right:24px !important;
    bottom:18px;
    z-index:30120;
    position:fixed !important;
    min-height:48px;
    padding:0 18px;
    background:linear-gradient(90deg,#6f2b3a,var(--pnb-green-dark)) !important;
    color:white !important;
    border-radius:12px !important;
    box-shadow:0 16px 36px rgba(111,43,58,.26) !important;
}

.pnb-chat-launcher-badge{
    display:none;
    position:absolute;
    top:-9px;
    right:-9px;
    min-width:22px;
    height:22px;
    padding:0 6px;
    align-items:center;
    justify-content:center;
    border:2px solid white;
    border-radius:999px;
    background:#f58a91;
    color:white !important;
    font-size:11px;
    font-weight:900;
    line-height:18px;
    box-shadow:0 8px 18px rgba(245,138,145,.34);
}

.pnb-chat-launcher-badge.is-visible{
    display:inline-flex;
}

@keyframes pnbMenuDrop{
    from{
        opacity:0;
        transform:translateY(-10px);
    }
    to{
        opacity:1;
        transform:translateY(0);
    }
}

body > h1,
.container > h1{
    color:var(--pnb-green-dark) !important;
    margin:24px 28px 18px !important;
    font-size:34px !important;
}

h1,h2,h3{
    color:var(--pnb-green-dark) !important;
    letter-spacing:0 !important;
}

.container{
    width:94% !important;
    max-width:1500px;
    margin:26px auto 38px !important;
}

.card,
.profile,
.nav,
.metric,
.alert-section,
form:not(td form){
    border-radius:8px !important;
    border:1px solid rgba(248,160,165,.07);
    box-shadow:var(--pnb-shadow) !important;
}

.card{
    background:rgba(255,255,255,.96) !important;
}

.info-user,
.empty{
    border-left:5px solid var(--pnb-green) !important;
    background:var(--pnb-soft) !important;
}

button,
.btn,
.btn-action,
input[type="submit"]{
    border-radius:6px !important;
    border:0 !important;
    font-weight:700 !important;
    text-decoration:none !important;
    box-shadow:0 3px 8px rgba(111,43,58,.07);
}

button,
.btn,
.btn-green{
    background:var(--pnb-green) !important;
    color:white !important;
}

button:hover,
.btn:hover,
.btn-green:hover{
    background:var(--pnb-green-dark) !important;
}

.pnb-quick-links button.pnb-menu-parent,
.pnb-quick-links button.pnb-menu-parent:hover{
    background:transparent !important;
    box-shadow:none !important;
}

.pnb-return-zone{
    padding:14px 0 4px;
    text-align:left;
}

.pnb-return-home{
    display:inline-block;
    padding:8px 12px !important;
    border-radius:999px !important;
    background:rgba(111,43,58,.07) !important;
    color:#6f2b3a !important;
    font-size:14px !important;
    font-weight:800 !important;
    text-decoration:none !important;
    box-shadow:none !important;
    border:1px solid rgba(111,43,58,.07) !important;
}

.pnb-return-home:hover{
    background:rgba(111,43,58,.07) !important;
}

.btn-accent{
    background:#f8a0a5 !important;
}

.btn-red{
    background:var(--pnb-red) !important;
}

input,
select,
textarea{
    border:1px solid #ffd9dc !important;
    border-radius:6px !important;
    background:white;
    color:var(--pnb-ink);
}

input:focus,
select:focus,
textarea:focus{
    outline:3px solid rgba(248,160,165,.06);
    border-color:var(--pnb-green) !important;
}

table{
    border-collapse:separate !important;
    border-spacing:0 !important;
    overflow:hidden;
    border-radius:8px;
    border:1px solid var(--pnb-line);
}

th{
    background:var(--pnb-green-dark) !important;
    color:white !important;
    border:0 !important;
}

td{
    border-color:var(--pnb-line) !important;
}

tr:nth-child(even){
    background:#ffffff !important;
}

.statut-ok,
.badge.ok{
    color:#6f2b3a !important;
}

.statut-attente,
.statut,
.badge.wait{
    color:#7b4650 !important;
}

.footer{
    color:var(--pnb-muted) !important;
}

.belel-signature{
    margin:28px auto 18px;
    padding:12px 18px;
    text-align:center;
    color:#7b4650;
    font-size:13px;
    font-weight:700;
}

.filters{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(170px,1fr));
    gap:10px;
    margin:12px 0 14px;
    padding:12px;
    background:#ffffff;
    border:1px solid var(--pnb-line);
    border-radius:8px;
}

.filters label{
    font-weight:bold;
    color:var(--pnb-green-dark);
    font-size:13px;
}

.filters input,
.filters select{
    margin-top:4px;
}

.official-print-header{
    display:grid;
    grid-template-columns:110px 1fr 110px;
    gap:16px;
    align-items:center;
    border-bottom:4px solid var(--pnb-green);
    padding-bottom:14px;
    margin-bottom:18px;
}

.official-print-logo{
    width:96px;
    height:96px;
    object-fit:contain;
}

.official-print-title{
    text-align:center;
    line-height:1.45;
}

.official-print-title strong{
    color:var(--pnb-green-dark);
    font-size:18px;
}

.official-meta{
    text-align:right;
    color:var(--pnb-muted);
    font-size:12px;
}

@media(max-width:760px){
    html{
        -webkit-text-size-adjust:100%;
    }

    body{
        min-width:0 !important;
        overflow-x:hidden !important;
    }

    .pnb-app-header{
        position:relative;
        align-items:center;
        flex-direction:row;
        flex-wrap:wrap;
        gap:10px;
        padding:10px 12px;
    }

    .pnb-brand{
        flex:1 1 calc(100% - 112px);
        gap:10px;
    }

    .pnb-logo{
        width:54px;
        height:54px;
        border-radius:8px;
        padding:4px;
    }

    .pnb-title strong{
        font-size:17px;
        line-height:1.05;
    }

    .pnb-title span{
        font-size:11px;
        line-height:1.2;
    }

    .pnb-chip{
        order:3;
        flex:1 1 100%;
        min-width:0;
        min-height:42px;
        padding:8px 14px;
        font-size:24px;
        letter-spacing:0;
    }

    .pnb-profile-menu{
        margin-left:auto;
        max-width:100%;
    }

    .pnb-user-badge{
        max-width:clamp(118px,38vw,180px);
        min-height:38px;
        padding:8px 10px;
        font-size:12px;
    }

    .pnb-user-badge span:first-child{
        overflow:hidden;
        text-overflow:ellipsis;
        white-space:nowrap;
    }

    .pnb-profile-dropdown{
        position:fixed;
        top:82px;
        right:12px;
        left:12px;
        min-width:0;
        z-index:120;
    }

    body > h1,
    .container > h1{
        margin-left:16px !important;
        margin-right:16px !important;
        font-size:25px !important;
        line-height:1.15;
    }

    h2{
        font-size:21px !important;
        line-height:1.2;
    }

    h3{
        font-size:18px !important;
        line-height:1.2;
    }

    .container,
    main,
    .messages-page{
        width:100% !important;
        max-width:none !important;
        margin:12px 0 26px !important;
        padding-left:12px !important;
        padding-right:12px !important;
    }

    .pnb-quick-access{
        position:sticky;
        top:0;
        align-items:stretch;
        flex-direction:column;
        gap:10px;
        min-height:0;
        margin-bottom:12px;
        padding:10px 12px;
    }

    .pnb-menu-toggle{
        display:inline-flex;
        width:100%;
        min-height:44px;
        font-size:15px;
    }

    .pnb-quick-links{
        display:grid;
        grid-template-columns:repeat(4,minmax(0,1fr));
        gap:8px;
        max-height:0;
        overflow:hidden;
        transition:max-height .35s ease, opacity .25s ease;
        opacity:0;
    }

    .pnb-quick-access.is-open .pnb-quick-links{
        max-height:80vh;
        overflow-y:auto;
        opacity:1;
    }

    .pnb-menu-group{
        display:flex;
        flex-direction:column;
    }

    .pnb-submenu{
        position:static;
        min-width:0;
        padding:4px 0 0;
        border:0;
        box-shadow:none;
        opacity:1;
        pointer-events:auto;
        transform:none;
        background:transparent;
    }

    .pnb-submenu a{
        margin-top:5px;
        padding-left:22px;
        border:1px solid rgba(111,43,58,.07);
    }

    .pnb-quick-links a,
    .pnb-menu-parent{
        min-height:58px;
        justify-content:center;
        padding:6px 7px;
        background:#ffffff !important;
        border:1px solid rgba(111,43,58,.07) !important;
        border-radius:6px !important;
        font-size:11px;
        text-align:center;
        white-space:normal;
    }

    .pnb-quick-links > a.is-icon-menu,
    .pnb-menu-parent.is-icon-menu{
        width:auto;
        flex-direction:column;
        gap:5px;
    }

    .pnb-menu-icon{
        width:24px;
        height:24px;
    }

    .is-icon-menu > .pnb-menu-label{
        position:static;
        min-width:0;
        padding:0;
        background:transparent;
        color:inherit;
        border-radius:0;
        font-size:12px;
        box-shadow:none;
        opacity:1;
        transform:none;
        pointer-events:auto;
    }

    .pnb-menu-chevron{
        display:none;
    }

    .pnb-submenu{
        grid-column:1 / -1;
    }

    .pnb-submenu a{
        min-height:42px;
        justify-content:flex-start;
        font-size:13px;
        text-align:left;
    }

    .filters{
        grid-template-columns:1fr !important;
        gap:8px;
        margin:10px 0 12px;
        padding:10px;
    }

    form:not(td form),
    .card,
    .profile,
    .section,
    .detail-block,
    .chart-card,
    .alert-section{
        width:100% !important;
        padding:14px !important;
        border-radius:8px !important;
    }

    input,
    select,
    textarea,
    button,
    .btn,
    .btn-action,
    input[type="submit"]{
        max-width:100%;
        font-size:16px !important;
    }

    input,
    select{
        min-height:44px;
    }

    textarea{
        min-height:96px;
    }

    button,
    .btn,
    .btn-action,
    input[type="submit"]{
        min-height:40px;
        display:inline-flex;
        align-items:center;
        justify-content:center;
        padding:9px 12px !important;
        line-height:1.1;
    }

    .table-wrapper,
    .pnb-archives-content{
        width:100%;
        overflow-x:visible !important;
    }

    table{
        width:100% !important;
        min-width:0 !important;
        border:0 !important;
        border-radius:0;
        background:transparent !important;
        box-shadow:none !important;
    }

    table thead,
    table > tr:first-child,
    table tbody > tr:first-child th{
        display:none;
    }

    table tr,
    table tbody,
    table td{
        display:block;
        width:100% !important;
    }

    table tr{
        margin:0 0 12px;
        overflow:hidden;
        background:white !important;
        border:1px solid var(--pnb-line);
        border-radius:8px;
        box-shadow:0 8px 20px rgba(111,43,58,.07);
    }

    table td{
        border:0 !important;
        border-bottom:1px solid var(--pnb-line) !important;
        padding:10px 12px !important;
    }

    table td:last-child{
        border-bottom:0 !important;
    }

    table td:empty{
        display:none;
    }

    .compact-main-row,
    .formation-summary{
        display:block !important;
    }

    .compact-actions{
        flex-wrap:wrap !important;
        justify-content:flex-start !important;
        gap:7px !important;
        white-space:normal !important;
    }

    .compact-actions .btn-action,
    .compact-actions .btn-neutral,
    .compact-actions button{
        flex:1 1 auto;
        min-width:108px;
    }

    .compact-line,
    .formation-meta,
    .compact-status{
        align-items:flex-start;
        flex-direction:column;
        gap:5px;
    }

    .formation-title{
        white-space:normal !important;
        overflow:visible !important;
    }

    .details-grid,
    .dashboard-grid,
    .calendar-alert-layout,
    .dashboard-visuals,
    .cards{
        display:grid !important;
        grid-template-columns:1fr !important;
        gap:12px !important;
    }

    .agent-picker-panel{
        max-height:52vh !important;
    }

    .agent-choice{
        min-height:46px;
        align-items:flex-start;
    }

    .pnb-chat-widget{
        right:10px !important;
        left:auto !important;
        width:min(390px,calc(100vw - 20px));
        max-height:76vh;
    }

    .pnb-chat-launcher{
        right:22px;
        left:auto;
        width:auto;
    }

    .pnb-chat-widget.is-open{
        border-radius:10px;
        bottom:8px;
    }

    .pnb-chat-header{
        min-height:44px;
    }

    .pnb-chat-title,
    .pnb-chat-expand,
    .pnb-chat-collapse,
    .pnb-chat-hide{
        min-height:44px;
        padding:0 8px;
    }

    .pnb-chat-messages{
        height:34vh;
    }

    .pnb-chat-form{
        align-items:stretch;
    }

    .pnb-chat-form input{
        min-height:40px;
    }

    .pnb-chat-form button{
        min-width:84px;
    }

    .official-print-header{
        grid-template-columns:64px 1fr;
        gap:10px;
    }

    .official-print-logo{
        width:58px;
        height:58px;
    }

    .official-meta{
        grid-column:1 / -1;
        text-align:left;
    }
}

@media(max-width:420px){
    .pnb-quick-links{
        grid-template-columns:repeat(3,minmax(0,1fr));
    }

    .pnb-quick-links a,
    .pnb-menu-parent{
        min-height:54px;
        font-size:10px;
    }

    .pnb-menu-icon{
        width:22px;
        height:22px;
    }

    .pnb-chip{
        font-size:22px;
    }

    body > h1,
    .container > h1{
        font-size:23px !important;
    }
}
@media print{
    .pnb-app-header,
    .filters,
    .retour,
    .pnb-chat-widget,
    .pnb-chat-launcher,
    a[href="/"],
    a[href="#"]{
        display:none !important;
    }

    body{
        background:white !important;
    }

    .official-print-header{
        display:grid !important;
    }

    .pnb-app-header{
        box-shadow:none;
        border-bottom:3px solid var(--pnb-green);
    }
}

.pnb-app-header{
    position:relative !important;
    z-index:30000 !important;
    overflow:visible !important;
}

.sarc-header-actions{
    position:relative !important;
    z-index:30010 !important;
    overflow:visible !important;
    pointer-events:auto !important;
}

.sarc-user-menu{
    position:relative !important;
    z-index:30020 !important;
    overflow:visible !important;
    pointer-events:auto !important;
}

.sarc-user-menu summary{
    pointer-events:auto !important;
}

.sarc-user-panel{
    position:fixed !important;
    right:24px !important;
    top:86px !important;
    z-index:30030 !important;
    pointer-events:auto !important;
}

.sarc-user-menu[open] .sarc-user-panel{
    display:grid !important;
}

.back-link,
.back-btn,
.retour,
.pnb-return-home,
.back,
.btn[href*="Retour"],
a[class*="back"],
a[class*="retour"]{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    min-height:44px !important;
    padding:10px 16px !important;
    border-radius:999px !important;
    border:1px solid rgba(255,255,255,.78) !important;
    background:linear-gradient(135deg,#6f2b3a,#f8a0a5) !important;
    color:#fff !important;
    text-decoration:none !important;
    font-weight:950 !important;
    font-size:15px !important;
    line-height:1.15 !important;
    text-shadow:0 1px 6px rgba(111,43,58,.07) !important;
    box-shadow:0 12px 26px rgba(111,43,58,.07) !important;
    white-space:normal !important;
    max-width:100% !important;
}

.back-link:hover,
.back-btn:hover,
.retour:hover,
.pnb-return-home:hover,
.back:hover,
a[class*="back"]:hover,
a[class*="retour"]:hover{
    filter:brightness(1.04) !important;
    transform:translateY(-1px);
}

.pnb-chat-widget,
.pnb-chat-launcher{
    left:auto !important;
    right:22px !important;
}

.pnb-chat-widget{
    bottom:18px !important;
}

.pnb-chat-widget.is-open{
    bottom:18px !important;
    border-radius:12px !important;
}

.pnb-chat-launcher{
    bottom:18px !important;
}

.sarc-notification-toast{
    position:fixed;
    right:24px;
    bottom:86px;
    z-index:30100;
    max-width:min(360px,calc(100vw - 48px));
    padding:14px 18px;
    border-radius:14px;
    background:linear-gradient(135deg,#6f2b3a,#f8a0a5);
    color:white;
    font-weight:950;
    box-shadow:0 18px 46px rgba(111,43,58,.24);
    opacity:0;
    pointer-events:none;
    transform:translateY(12px);
    transition:opacity .2s ease,transform .2s ease;
}

.sarc-notification-toast.is-visible{
    opacity:1;
    transform:translateY(0);
}

.pnb-notification-badge,
.pnb-chat-unread-badge,
.pnb-chat-launcher-badge,
.thread-unread-count{
    animation:sarcNotifyPulse 1.25s ease-in-out infinite;
}

@keyframes sarcNotifyPulse{
    0%,100%{transform:scale(1);box-shadow:0 0 0 rgba(245,138,145,0);}
    50%{transform:scale(1.08);box-shadow:0 0 0 6px rgba(245,138,145,.16);}
}

@media(max-width:640px){
    .pnb-chat-widget,
    .pnb-chat-launcher{
        left:auto !important;
        right:10px !important;
        width:min(340px,calc(100vw - 20px)) !important;
    }

    .pnb-chat-widget.is-open{
        width:calc(100vw - 20px) !important;
        max-height:calc(100vh - 20px);
    }

    .pnb-chat-widget.is-open .pnb-chat-body{
        grid-template-columns:1fr;
        grid-template-areas:
            "toolbar"
            "filters"
            "threads"
            "conversation"
            "form";
    }

    .pnb-chat-threads{
        max-height:156px;
        border-right:0;
        border-bottom:1px solid var(--pnb-line);
    }

    .pnb-chat-messages{
        height:260px;
    }

    .pnb-chat-toolbar{
        flex-direction:column;
        align-items:stretch;
    }
}

.pnb-chat-threads .thread-unread-count{
    animation:none !important;
    transform:translateY(-50%) !important;
}

body:not(.portal-page) .container > .pnb-return-home:last-child{
    position:fixed !important;
    left:32px !important;
    bottom:42px !important;
    z-index:120 !important;
    margin:0 !important;
}

@media(max-width:640px){
    body:not(.portal-page) .container > .pnb-return-home:last-child{
        left:16px !important;
        right:16px !important;
        bottom:76px !important;
    }
}
