:root{--blue:#2563eb;--blue-d:#1D4ED8;--ink:#1f2a37;--muted:#64748b;--line:#e6eaf0;--bg:#f6f8fb;}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;background:var(--bg);color:var(--ink);font-size:14px}
a{color:inherit;text-decoration:none}
.app{display:flex;min-height:100vh}
/* Sidebar */
.sidebar{width:230px;background:#fff;border-right:1px solid var(--line);flex-shrink:0;padding:0 0 20px}
.brand{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;flex-direction:column}
.brand-name{font-weight:800;color:var(--blue);font-size:20px}
.brand-sub{font-size:11px;color:var(--muted);margin-top:2px}
.nav-group{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;font-weight:700;padding:16px 20px 6px}
.sidebar nav a{display:block;padding:9px 20px;color:#334155;font-size:13.5px;font-weight:500;border-left:3px solid transparent}
.sidebar nav a:hover{background:#f1f5f9}
.sidebar nav a.active{background:#eff4ff;color:var(--blue-d);border-left-color:var(--blue);font-weight:600}
/* Main */
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{height:60px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 26px}
.page-title{font-weight:700;font-size:17px}
.user-box{display:flex;align-items:center;gap:10px}
.u-name{font-weight:600;font-size:13px}
.u-role{font-size:11px;color:#fff;background:var(--blue);padding:2px 9px;border-radius:20px}
.logout{font-size:12px;color:var(--muted);border:1px solid var(--line);padding:5px 11px;border-radius:8px}
.logout:hover{background:#f1f5f9}
.content{padding:24px 26px}
.flash{margin:14px 26px 0;padding:11px 16px;border-radius:10px;font-size:13.5px}
.flash.success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.flash.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}
/* Cards / KPI */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:18px}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px}
.kpi .lbl{font-size:12px;color:var(--muted)}
.kpi .val{font-size:23px;font-weight:800;margin-top:4px}
.section-title{font-weight:700;font-size:15px;margin:0 0 10px;padding-left:9px;border-left:3px solid var(--blue)}
/* Tables */
table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
th{background:#f1f5f9;text-align:left;padding:10px 12px;font-size:11px;text-transform:uppercase;color:#64748b;letter-spacing:.03em}
td{padding:10px 12px;border-top:1px solid var(--line);font-size:13.5px}
tr:hover td{background:#fafcff}
/* Forms */
label{display:block;font-size:12px;color:var(--muted);margin-bottom:4px;font-weight:600}
input,select,textarea{width:100%;padding:9px 11px;border:1px solid #cbd5e1;border-radius:9px;font-size:13.5px;font-family:inherit;background:#fff}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.row{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.field{flex:1;min-width:150px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
/* Buttons */
.btn{display:inline-block;background:var(--blue);color:#fff;border:none;padding:9px 16px;border-radius:9px;font-size:13.5px;font-weight:600;cursor:pointer;text-align:center}
.btn:hover{background:var(--blue-d)}
.btn.ghost{background:#fff;color:#334155;border:1.5px solid #cbd5e1}
.btn.ghost:hover{border-color:var(--blue);color:var(--blue-d)}
.btn.sm{padding:5px 10px;font-size:12px;border-radius:7px}
.btn.danger{background:#dc2626}
.btn.green{background:#16a34a}
/* Tags */
.tag{display:inline-block;padding:2px 10px;border-radius:20px;font-size:11.5px;font-weight:600}
.tag.green{background:#dcfce7;color:#166534}.tag.red{background:#fee2e2;color:#991b1b}
.tag.blue{background:#dbeafe;color:#1e40af}.tag.amber{background:#fef3c7;color:#92400e}
.tag.violet{background:#ede9fe;color:#5b21b6}.tag.gray{background:#e2e8f0;color:#334155}
/* Op nav (stocks) */
.op-nav{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.op-navbtn{padding:8px 14px;border:1.5px solid #cbd5e1;background:#fff;border-radius:10px;font-size:13px;font-weight:600;color:#334155}
.op-navbtn:hover{border-color:var(--blue);color:var(--blue-d)}
.op-navbtn.on{background:var(--blue);border-color:var(--blue);color:#fff}
.op-badge{display:inline-block;margin-left:6px;background:#f59e0b;color:#fff;border-radius:10px;font-size:11px;padding:1px 7px}
.doc-step{font-size:12px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.05em;margin:14px 0 8px}
.muted{color:var(--muted)}
.right{text-align:right}.center{text-align:center}
.pill-tabs{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.pill-tabs a{padding:7px 14px;border-radius:20px;font-size:13px;font-weight:600;border:1px solid var(--line);color:#334155;background:#fff}
.pill-tabs a.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.spacer{height:18px}
.mt{margin-top:18px}
/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a8a,#2563eb)}
.login-card{background:#fff;border-radius:18px;padding:34px;width:360px;box-shadow:0 20px 50px rgba(0,0,0,.25)}
.login-card h1{color:var(--blue);margin:0 0 4px;font-size:26px}
.login-card p{color:var(--muted);margin:0 0 20px;font-size:13px}
.login-card .field{margin-bottom:14px}

/* Légende des statuts (bas de page) */
.legend{margin-top:26px;padding:14px 16px;background:#fff;border:1px solid var(--line);border-radius:12px}
.legend-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:10px}
.legend-items{display:flex;flex-wrap:wrap;gap:10px 22px}
.legend-item{display:flex;align-items:center;gap:8px}
.legend-desc{font-size:12.5px;color:#334155}

/* Modal de choix d'impression (Facture / Reçu) */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}
.modal-box{background:#fff;border-radius:16px;max-width:460px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.25);overflow:hidden}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line);font-weight:700}
.modal-x{border:none;background:transparent;font-size:18px;cursor:pointer;color:var(--muted);line-height:1}
#docModalBody{padding:18px 20px}
.modal-sub{font-size:13px;color:var(--muted);margin:0 0 12px}
.modal-actions{display:flex;gap:10px;flex-wrap:wrap}
.modal-actions .btn{flex:1;justify-content:center;text-align:center;padding:12px}
.modal-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);font-size:13px}
.modal-row:last-child{border-bottom:none}
.modal-row-act{display:flex;gap:6px;white-space:nowrap}

/* Modal — visualisation des versements */
table.ledger{width:100%;border-collapse:collapse;font-size:13px}
table.ledger th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:6px 8px;border-bottom:1px solid var(--line)}
table.ledger th.r,table.ledger td.r{text-align:right}
table.ledger td{padding:7px 8px;border-bottom:1px solid var(--line)}
.ledger-tot{margin-top:14px;border-top:2px solid #0f172a;padding-top:10px}
.ledger-tot>div{display:flex;justify-content:space-between;padding:4px 8px;font-size:13px}
.ledger-tot>div b{font-size:14px}
.ledger-tot>div.due{color:#b45309;font-weight:700}
.ledger-tot>div.ok{color:#166534;font-weight:700}

/* ============================================================
   THÈME — Sidebar dégradée bleue + logo animé + login animé
   ============================================================ */

/* --- Sidebar en dégradé bleu --- */
.sidebar{background:linear-gradient(180deg,#172554 0%,#1e3a8a 48%,#1d4ed8 100%);border-right:none;box-shadow:2px 0 22px rgba(15,23,42,.18)}
.brand{border-bottom:1px solid rgba(255,255,255,.12);display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:22px 16px 20px}
.brand-name{color:#fff;font-weight:800;font-size:20px;letter-spacing:.4px;text-shadow:0 2px 10px rgba(0,0,0,.25)}
.brand-sub{color:rgba(255,255,255,.65);font-size:11px;margin-top:0}
.nav-group{color:rgba(255,255,255,.45);font-weight:700}
.sidebar nav a{color:rgba(255,255,255,.82);border-left:3px solid transparent;transition:background .18s,color .18s,padding .18s}
.sidebar nav a:hover{background:rgba(255,255,255,.10);color:#fff;padding-left:24px}
.sidebar nav a.active{background:linear-gradient(90deg,rgba(255,255,255,.18),rgba(255,255,255,.04));color:#fff;border-left-color:#93c5fd;font-weight:700}

/* --- Pastille logo animée (sidebar + accueil) --- */
.logo-badge{position:relative;display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:18px;
  background:linear-gradient(135deg,#60a5fa,#2563eb 55%,#1e3a8a);color:#fff;font-weight:800;font-size:22px;letter-spacing:.5px;
  box-shadow:0 10px 26px rgba(37,99,235,.5);animation:floatY 4.5s ease-in-out infinite}
.logo-badge img{max-width:42px;max-height:42px;border-radius:10px;object-fit:contain}
.brand .logo-badge{width:84px;height:84px;border-radius:20px}
.brand .logo-badge img{max-width:64px;max-height:64px;border-radius:12px}
.logo-badge::before,.logo-badge::after{content:"";position:absolute;inset:-5px;border-radius:22px;border:2px solid rgba(147,197,253,.7);animation:ringPulse 2.6s ease-out infinite}
.logo-badge::after{animation-delay:1.3s}
@keyframes ringPulse{0%{transform:scale(.92);opacity:.85}70%{opacity:0}100%{transform:scale(1.55);opacity:0}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.logo-badge.lg{width:118px;height:118px;border-radius:28px;font-size:40px}
.logo-badge.lg img{max-width:90px;max-height:90px}

/* --- Hero du tableau de bord --- */
.dash-hero{display:flex;align-items:center;gap:20px;padding:22px 24px;margin-bottom:20px;border-radius:18px;
  background:linear-gradient(120deg,#1e3a8a,#2563eb 60%,#3b82f6);color:#fff;box-shadow:0 14px 40px rgba(37,99,235,.28);overflow:hidden;position:relative;
  animation:heroIn .7s cubic-bezier(.2,.8,.2,1) both}
.dash-hero::after{content:"";position:absolute;right:-60px;top:-60px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 70%)}
.dash-hero h1{margin:0;font-size:24px;font-weight:800}
.dash-hero p{margin:4px 0 0;opacity:.85;font-size:13.5px}
@keyframes heroIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.dash-hero .logo-badge{background:rgba(255,255,255,.16);box-shadow:0 8px 22px rgba(0,0,0,.18)}
.dash-hero .logo-badge::before,.dash-hero .logo-badge::after{border-color:rgba(255,255,255,.7)}

/* Apparition douce des KPI du tableau de bord */
.dash-cards .card{animation:cardIn .5s ease both}
.dash-cards .card:nth-child(1){animation-delay:.05s}.dash-cards .card:nth-child(2){animation-delay:.12s}
.dash-cards .card:nth-child(3){animation-delay:.19s}.dash-cards .card:nth-child(4){animation-delay:.26s}
.dash-cards .card:nth-child(5){animation-delay:.33s}.dash-cards .card:nth-child(6){animation-delay:.40s}
@keyframes cardIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}

/* ============================================================
   PAGE DE CONNEXION
   ============================================================ */
.login-body{overflow-x:hidden}
.login-bg{position:fixed;inset:0;z-index:-3;background:linear-gradient(125deg,#070d1c,#0f1f4d,#1d4ed8,#1e40af,#0f1f4d);background-size:360% 360%;animation:bgShift 22s ease infinite}
@keyframes bgShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
/* Voile aurore qui respire */
.login-aurora{position:fixed;inset:-20%;z-index:-2;pointer-events:none;
  background:
    radial-gradient(40% 55% at 18% 22%,rgba(96,165,250,.40),transparent 60%),
    radial-gradient(38% 50% at 82% 30%,rgba(59,130,246,.34),transparent 62%),
    radial-gradient(50% 60% at 50% 92%,rgba(37,99,235,.32),transparent 65%);
  filter:blur(20px);animation:auroraDrift 16s ease-in-out infinite;opacity:.9}
@keyframes auroraDrift{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(0,-3%,0) scale(1.06)}}
/* Grille fine en perspective */
.login-grid{position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.16;
  background-image:linear-gradient(rgba(255,255,255,.35) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.35) 1px,transparent 1px);
  background-size:46px 46px;mask-image:radial-gradient(circle at 50% 40%,#000,transparent 78%);-webkit-mask-image:radial-gradient(circle at 50% 40%,#000,transparent 78%);
  animation:gridPan 24s linear infinite}
@keyframes gridPan{from{background-position:0 0}to{background-position:46px 46px}}
.login-blob{position:fixed;border-radius:50%;filter:blur(56px);opacity:.32;z-index:-1;animation:floatBlob 16s ease-in-out infinite;mix-blend-mode:screen}
.login-blob.b1{width:360px;height:360px;background:#3b82f6;top:-90px;left:-70px}
.login-blob.b2{width:320px;height:320px;background:#60a5fa;bottom:-100px;right:-50px;animation-delay:3s}
.login-blob.b3{width:240px;height:240px;background:#1e40af;top:38%;right:16%;animation-delay:6s}
@keyframes floatBlob{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(30px,-34px) scale(1.08)}}
.login-wrap{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;background:none;padding:40px 24px}
.login-shell{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start;max-width:980px;width:100%}
@media(max-width:820px){.login-shell{grid-template-columns:1fr;gap:24px}.login-hero{text-align:center}.login-features{margin:0 auto}}

.login-hero{color:#fff}
.login-head{display:flex;align-items:center;gap:18px;margin-bottom:16px}
@media(max-width:820px){.login-head{justify-content:center}}
.login-head .logo-badge{margin-bottom:0;flex:0 0 auto;animation:badgeFloat 5s ease-in-out infinite}
.login-head-txt{text-align:left}
@keyframes badgeFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.login-hero h1{font-size:44px;font-weight:800;margin:0;letter-spacing:.5px;line-height:1;animation:slideUp .7s cubic-bezier(.2,.8,.2,1) both}
.grad-text{background:linear-gradient(100deg,#ffffff,#bfdbfe 40%,#ffffff 70%,#93c5fd);-webkit-background-clip:text;background-clip:text;color:transparent;background-size:220% 100%;animation:shimmer 6s linear infinite;text-shadow:0 6px 26px rgba(0,0,0,.25)}
@keyframes shimmer{0%{background-position:0% 0}100%{background-position:220% 0}}
.login-hero .tag-line{font-size:13px;opacity:.82;margin:5px 0 0;letter-spacing:.06em;text-transform:uppercase;animation:slideUp .7s .08s cubic-bezier(.2,.8,.2,1) both}
.login-lead{font-size:18px;line-height:1.5;font-weight:600;color:#eaf2ff;max-width:500px;margin:0 0 18px;text-shadow:0 2px 14px rgba(0,0,0,.25);animation:slideUp .7s .16s cubic-bezier(.2,.8,.2,1) both}
@media(max-width:820px){.login-lead{margin-left:auto;margin-right:auto}}

.login-features{display:grid;grid-template-columns:1fr 1fr;gap:13px;max-width:520px}
@media(max-width:820px){.login-features{margin:0 auto}}
@media(max-width:520px){.login-features{grid-template-columns:1fr}}
.feature-card{display:flex;align-items:center;gap:13px;border-radius:16px;padding:12px 14px;color:#fff;position:relative;overflow:hidden;
  border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);text-align:left;
  transition:transform .22s cubic-bezier(.2,.8,.2,1),box-shadow .22s,border-color .22s;
  animation:featReveal .65s cubic-bezier(.2,.9,.25,1.12) both;transform-origin:center bottom;will-change:transform,opacity}
@keyframes featReveal{0%{opacity:0;transform:translateY(26px) scale(.92) rotateX(10deg)}100%{opacity:1;transform:none}}
.feature-card::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.18) 50%,transparent 70%);transform:translateX(-130%);transition:transform .6s}
.feature-card:hover{transform:translateY(-4px) scale(1.015);border-color:rgba(255,255,255,.36);box-shadow:0 18px 40px rgba(8,17,40,.5)}
.feature-card:hover::after{transform:translateX(130%)}
.fc-chip{position:relative;z-index:1;flex:0 0 44px;width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.3);box-shadow:0 6px 16px rgba(8,17,40,.4)}
.fc-chip svg{width:23px;height:23px;color:#fff}
.feature-card h3{margin:0 0 2px;font-size:14px;font-weight:700;position:relative;z-index:1}
.feature-card p{margin:0;font-size:12px;opacity:.9;line-height:1.4;position:relative;z-index:1}
.feature-card:nth-child(1){animation-delay:.22s}.feature-card:nth-child(2){animation-delay:.32s}
.feature-card:nth-child(3){animation-delay:.42s}.feature-card:nth-child(4){animation-delay:.52s}
.feature-card:nth-child(5){animation-delay:.62s}.feature-card:nth-child(6){animation-delay:.72s}
/* Fonds colorés par module */
.fc-blue{background:linear-gradient(135deg,rgba(59,130,246,.42),rgba(29,78,216,.26))}     .fc-blue .fc-chip{background:linear-gradient(135deg,#60a5fa,#2563eb)}
.fc-amber{background:linear-gradient(135deg,rgba(245,158,11,.42),rgba(180,83,9,.26))}      .fc-amber .fc-chip{background:linear-gradient(135deg,#fbbf24,#d97706)}
.fc-emerald{background:linear-gradient(135deg,rgba(16,185,129,.42),rgba(4,120,87,.26))}    .fc-emerald .fc-chip{background:linear-gradient(135deg,#34d399,#059669)}
.fc-violet{background:linear-gradient(135deg,rgba(139,92,246,.42),rgba(91,33,182,.26))}    .fc-violet .fc-chip{background:linear-gradient(135deg,#a78bfa,#7c3aed)}
.fc-cyan{background:linear-gradient(135deg,rgba(6,182,212,.42),rgba(14,116,144,.26))}      .fc-cyan .fc-chip{background:linear-gradient(135deg,#22d3ee,#0891b2)}
.fc-rose{background:linear-gradient(135deg,rgba(244,63,94,.42),rgba(159,18,57,.26))}       .fc-rose .fc-chip{background:linear-gradient(135deg,#fb7185,#e11d48)}

.login-credit{margin:16px 0 0;font-size:12.5px;color:rgba(255,255,255,.75);letter-spacing:.02em;animation:slideUp .7s .9s both}
.login-credit b{color:#fff;font-weight:700}

.login-card{position:relative;background:rgba(255,255,255,.97);border:1px solid rgba(255,255,255,.6);border-radius:22px;padding:34px 34px 28px;
  box-shadow:0 30px 70px rgba(8,17,40,.45),0 2px 0 rgba(255,255,255,.6) inset;overflow:hidden;
  animation:cardPop .7s .15s cubic-bezier(.2,.9,.25,1.1) both}
.login-card::before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:linear-gradient(90deg,#1d4ed8,#3b82f6,#60a5fa,#3b82f6,#1d4ed8);background-size:200% 100%;animation:barFlow 5s linear infinite}
@keyframes barFlow{from{background-position:0 0}to{background-position:200% 0}}
@keyframes cardPop{from{opacity:0;transform:translateY(28px) scale(.97)}to{opacity:1;transform:none}}
.login-card-ic{width:54px;height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:14px;
  background:linear-gradient(135deg,#3b82f6,#1d4ed8);box-shadow:0 10px 24px rgba(37,99,235,.4);animation:icPulse 3.2s ease-in-out infinite}
.login-card-ic svg{width:26px;height:26px}
@keyframes icPulse{0%,100%{box-shadow:0 10px 24px rgba(37,99,235,.4)}50%{box-shadow:0 10px 34px rgba(37,99,235,.7)}}
.login-card h1{font-size:26px;font-weight:800;margin:0 0 4px;color:#0f172a}
.login-card>p{margin:0 0 18px;color:#64748b;font-size:13.5px}
.login-field{margin-bottom:14px;animation:slideUp .6s both}
.login-field:nth-of-type(1){animation-delay:.28s}.login-field:nth-of-type(2){animation-delay:.36s}
.login-field input{transition:border-color .18s,box-shadow .18s,background .18s}
.login-field input:focus{box-shadow:0 0 0 4px rgba(37,99,235,.15);background:#fbfdff}
.login-btn{width:100%;margin-top:6px;position:relative;overflow:hidden;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:0;
  box-shadow:0 10px 24px rgba(37,99,235,.36);transition:transform .12s,box-shadow .18s;animation:slideUp .6s .44s both}
.login-btn::after{content:"";position:absolute;top:0;left:-130%;width:60%;height:100%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-18deg);transition:left .6s}
.login-btn:hover{transform:translateY(-2px);box-shadow:0 16px 32px rgba(37,99,235,.5)}
.login-btn:hover::after{left:140%}
.login-card a{color:#1d4ed8;font-weight:600;text-decoration:none}
.login-card a:hover{text-decoration:underline}
.login-default{margin-top:6px;text-align:center;font-size:12px;color:#94a3b8}
@keyframes slideUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

@media(prefers-reduced-motion:reduce){
  .logo-badge,.logo-badge::before,.logo-badge::after,.dash-hero,.dash-cards .card,.login-bg,.login-blob,.login-aurora,.login-grid,
  .login-hero .logo-badge,.grad-text,.login-hero h1,.login-hero .tag-line,.login-lead,.feature-card,.feature-card::after,.login-credit,
  .login-card,.login-card::before,.login-card-ic,.login-field,.login-btn{animation:none!important}
}

/* --- Barre de recherche / filtre de liste --- */
.filter-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:14px}
.filter-bar .filter-input{flex:1;min-width:200px;max-width:360px}
.filter-bar select{width:auto;min-width:150px}

/* --- Header : cloche + menu utilisateur --- */
.topbar-right{display:flex;align-items:center;gap:14px}
.hdrmenu{position:relative}
.bell-btn{position:relative;background:#fff;border:1px solid var(--line);border-radius:11px;width:42px;height:40px;cursor:pointer;line-height:0;color:#475569;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,color .15s,box-shadow .15s}
.bell-btn svg{width:21px;height:21px}
.bell-btn:hover{background:#eff5ff;color:#1d4ed8;box-shadow:0 4px 10px rgba(37,99,235,.14)}
.bell-badge{position:absolute;top:-6px;right:-6px;background:#dc2626;color:#fff;font-size:10px;font-weight:700;min-width:17px;height:17px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.user-trigger{display:flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--line);border-radius:10px;padding:5px 10px;cursor:pointer}
.user-trigger:hover{background:#f1f5f9}
.u-stack{display:flex;flex-direction:column;align-items:flex-end;line-height:1.2}
.user-trigger .caret{color:var(--muted);font-size:11px}
.dropdown{position:absolute;right:0;top:46px;width:300px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 18px 40px rgba(15,23,42,.18);display:none;z-index:60;overflow:hidden}
.dropdown.open{display:block}
#userMenu{width:210px}
.dd-head{display:flex;justify-content:space-between;align-items:center;padding:11px 14px;border-bottom:1px solid var(--line);font-weight:700;font-size:13px}
.dd-mini{background:transparent;border:none;color:var(--blue);font-size:12px;font-weight:600;cursor:pointer}
.dd-empty{padding:18px 14px;color:var(--muted);font-size:13px;text-align:center}
.dd-item{display:block;padding:10px 14px;border-bottom:1px solid var(--line);color:#1f2a37}
.dd-item:hover{background:#f6f8fb}
.dd-item.unread{background:#f0f7ff}
.dd-title{font-size:13px;font-weight:600;display:flex;align-items:center;gap:7px}
.dd-msg{font-size:12px;color:var(--muted);margin-top:2px}
.dd-time{font-size:11px;color:#94a3b8;margin-top:3px}
.dd-all{display:block;text-align:center;padding:10px;font-size:12.5px;font-weight:600;color:var(--blue);background:#fafbfd}
.dd-all:hover{background:#f1f5f9}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.dot.blue{background:var(--blue)}.dot.green{background:#16a34a}.dot.amber{background:#d97706}.dot.red{background:#dc2626}.dot.gray{background:#94a3b8}

/* --- Workflows --- */
.wf-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px}
.wf-card{transition:transform .15s,box-shadow .15s}
.wf-card:hover{transform:translateY(-2px)}
.wf-steps{margin:6px 0 0;padding-left:18px;font-size:13px;color:#334155}
.wf-steps li{margin:3px 0}

/* ============================================================
   FINITION PROFESSIONNELLE (couche de raffinement)
   ============================================================ */
body{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.content{max-width:1280px}
.card{border-radius:16px;box-shadow:0 1px 2px rgba(16,24,40,.04),0 10px 26px rgba(16,24,40,.05);transition:box-shadow .18s,transform .12s}
.card:hover{box-shadow:0 1px 2px rgba(16,24,40,.05),0 16px 38px rgba(16,24,40,.08)}
.kpi .val{font-weight:800;font-size:26px;letter-spacing:-.02em;margin-top:2px}
.kpi .lbl{text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600;color:#94a3b8}
.section-title{letter-spacing:-.01em}
table{border-radius:14px;box-shadow:0 1px 2px rgba(16,24,40,.03)}
thead th{background:#f8fafc;text-transform:uppercase;letter-spacing:.03em;font-size:11px;color:#64748b;font-weight:700;border-bottom:1px solid var(--line)}
tbody tr{transition:background .12s}
tbody tr:hover{background:#fafcff}
.btn{border-radius:10px;box-shadow:0 1px 2px rgba(37,99,235,.18);transition:background .15s,box-shadow .15s,transform .05s}
.btn:hover{box-shadow:0 5px 14px rgba(37,99,235,.28)}
.btn:active{transform:translateY(1px)}
.btn.ghost{box-shadow:none}
.btn.ghost:hover{box-shadow:0 4px 10px rgba(16,24,40,.06)}
.btn.green{box-shadow:0 1px 2px rgba(22,163,74,.2)}.btn.green:hover{box-shadow:0 5px 14px rgba(22,163,74,.3)}
.btn.red{box-shadow:0 1px 2px rgba(220,38,38,.2)}.btn.red:hover{box-shadow:0 5px 14px rgba(220,38,38,.3)}
input,select,textarea{border-radius:10px;transition:border-color .15s,box-shadow .15s}
.tag{font-weight:600;letter-spacing:.01em;border-radius:20px}
.flash{box-shadow:0 6px 18px rgba(16,24,40,.06);border-radius:12px}
.pill-tabs a{transition:background .15s,color .15s,border-color .15s}
.topbar{box-shadow:0 1px 0 rgba(16,24,40,.04)}

/* ============================================================
   TABLEAU DE BORD — carte utilisateur + KPI colorés animés
   ============================================================ */
.dash-top{display:grid;grid-template-columns:1fr 320px;gap:16px;margin-bottom:20px;align-items:stretch}
.dash-top .dash-hero{margin-bottom:0}
@media(max-width:900px){.dash-top{grid-template-columns:1fr}}

.user-card{display:flex;align-items:center;gap:16px;animation:cardIn .6s cubic-bezier(.2,.8,.2,1) both;animation-delay:.1s}
.ucard-avatar{width:72px;height:72px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  font-size:26px;font-weight:800;color:#fff;background:linear-gradient(135deg,#3b82f6,#1e3a8a);box-shadow:0 8px 22px rgba(37,99,235,.35);overflow:hidden}
.ucard-avatar img{width:100%;height:100%;object-fit:cover}
.ucard-info{min-width:0}
.ucard-name{font-size:18px;font-weight:600;line-height:1.2}
.ucard-name b{font-weight:800}
.ucard-meta{font-size:12px;color:var(--muted);margin-top:4px;word-break:break-all}
.ucard-info .tag{margin-top:5px}

/* KPI colorés */
.dash-cards .card.kpi{display:flex;align-items:center;gap:14px;position:relative;overflow:hidden;border:1px solid var(--line)}
.dash-cards .card.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px}
.kpi-ic{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 6px 16px rgba(16,24,40,.16)}
.kpi-ic svg{width:24px;height:24px}
.dash-cards .kpi .val{font-size:24px;font-weight:800;letter-spacing:-.02em}
.k-blue{background:linear-gradient(135deg,#eff5ff,#fff)}    .k-blue::before{background:#2563eb}    .k-blue .kpi-ic{background:linear-gradient(135deg,#60a5fa,#1d4ed8)}    .k-blue .val{color:#1d4ed8}
.k-amber{background:linear-gradient(135deg,#fff7ed,#fff)}   .k-amber::before{background:#f59e0b}   .k-amber .kpi-ic{background:linear-gradient(135deg,#fbbf24,#d97706)}   .k-amber .val{color:#b45309}
.k-violet{background:linear-gradient(135deg,#f5f3ff,#fff)}  .k-violet::before{background:#7c3aed}  .k-violet .kpi-ic{background:linear-gradient(135deg,#a78bfa,#6d28d9)}  .k-violet .val{color:#6d28d9}
.k-teal{background:linear-gradient(135deg,#ecfeff,#fff)}    .k-teal::before{background:#0891b2}    .k-teal .kpi-ic{background:linear-gradient(135deg,#22d3ee,#0e7490)}    .k-teal .val{color:#0e7490}
.k-emerald{background:linear-gradient(135deg,#ecfdf5,#fff)} .k-emerald::before{background:#059669} .k-emerald .kpi-ic{background:linear-gradient(135deg,#34d399,#047857)} .k-emerald .val{color:#047857}
.k-indigo{background:linear-gradient(135deg,#eef2ff,#fff)}  .k-indigo::before{background:#4f46e5}  .k-indigo .kpi-ic{background:linear-gradient(135deg,#818cf8,#4338ca)}  .k-indigo .val{color:#4338ca}

/* Bel effet d'apparition (rebond léger, en cascade) */
.dash-cards .card{animation:kpiPop .6s cubic-bezier(.22,1.2,.36,1) both}
@keyframes kpiPop{0%{opacity:0;transform:translateY(20px) scale(.94)}100%{opacity:1;transform:none}}
.dash-cards .card.kpi:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(16,24,40,.12)}

/* --- Actions de la ligne réservation (style pro) --- */
.res-actions{display:flex;flex-direction:column;gap:7px;min-width:220px}
.res-actions .grp{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin:0}
.res-actions .btn.sm{padding:7px 13px;border-radius:9px;font-weight:600}
.res-actions input,.res-actions select{height:32px;border-radius:8px;font-size:13px}
.btn.soft{background:#eef4ff;color:#1d4ed8;border:1px solid #dbeafe;box-shadow:none}
.btn.soft:hover{background:#e0ecff;box-shadow:0 4px 10px rgba(37,99,235,.14)}
.btn.soft:disabled{background:#f1f5f9;color:#94a3b8;border-color:#e2e8f0}

/* --- Ligne réservation : détail dépliable (bouton Visualiser) --- */
.res-toggle.on{background:#1d4ed8;color:#fff;border-color:#1d4ed8}
.res-detail > td{background:#f6faff;border-top:none;padding:14px 18px;box-shadow:inset 0 2px 0 #dbeafe}
.res-detail .res-actions{flex-direction:row;flex-wrap:wrap;align-items:center;gap:14px;min-width:0}
.res-detail .res-actions .grp{gap:7px}

/* --- Alerte Versement en attente (cloche + dashboard) --- */
.bell-btn.has-alert{color:#b45309;border-color:#fcd34d;background:#fffbeb;animation:bellpulse 1.8s ease-in-out infinite}
@keyframes bellpulse{0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,.45)}50%{box-shadow:0 0 0 6px rgba(245,158,11,0)}}
.dd-pending{background:#fffbeb}
.pending-card{display:flex;align-items:center;gap:16px;text-decoration:none;background:linear-gradient(135deg,#fff7ed,#fffbeb);border:1.5px solid #fdba74;border-radius:16px;padding:15px 20px;margin-bottom:18px;animation:pendglow 2s ease-in-out infinite;position:relative;overflow:hidden}
@keyframes pendglow{0%,100%{box-shadow:0 0 0 0 rgba(249,115,22,.34)}50%{box-shadow:0 0 0 9px rgba(249,115,22,0)}}
.pending-card .pc-ic{width:48px;height:48px;border-radius:13px;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;flex:0 0 48px;box-shadow:0 6px 14px rgba(245,158,11,.4);animation:pcbob 1.6s ease-in-out infinite}
@keyframes pcbob{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.pending-card .pc-title{font-weight:800;font-size:15px;color:#9a3412}
.pending-card .pc-sub{font-size:13px;color:#b45309;margin-top:2px}
.pending-card .pc-go{margin-left:auto;font-weight:700;color:#ea580c;font-size:13px;white-space:nowrap}
.pending-card:hover{border-color:#fb923c;transform:translateY(-1px)}

/* chips poste de recette dans la carte d'alerte */
.pending-card .pc-points{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.pending-card .pc-chip{font-size:11.5px;font-weight:700;color:#9a3412;background:#ffedd5;border:1px solid #fdba74;border-radius:20px;padding:2px 9px}
/* Panneau "versements en attente par poste" (comptable) */
.dep-by-point{display:flex;flex-wrap:wrap;gap:10px;margin:6px 0 14px}
.dbp{flex:1;min-width:150px;border-radius:14px;padding:12px 14px;background:linear-gradient(135deg,#fff7ed,#fffbeb);border:1.5px solid #fdba74;animation:pendglow 2.4s ease-in-out infinite}
.dbp .dbp-lbl{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#b45309}
.dbp .dbp-val{font-size:19px;font-weight:800;color:#9a3412;margin-top:3px}
.dbp.tot{background:linear-gradient(135deg,#ecfdf5,#f0fdf4);border-color:#6ee7b7}
.dbp.tot .dbp-lbl{color:#047857}.dbp.tot .dbp-val{color:#065f46}

/* Carte "versement en attente" cliquable (caissier/accueil/barman) */
.pending-card-btn{width:100%;font:inherit;cursor:pointer;text-align:left;color:#7c2d12}
.pending-card-btn:hover{border-color:#fb923c}
.cancel-note{margin:2px 0 6px;background:#fef2f2;border:1px solid #fecaca;color:#991b1b;border-radius:9px;padding:8px 12px;font-size:12.5px}

/* ============================================================
   TABLEAU DE BORD — FINITIONS PROFESSIONNELLES
   ============================================================ */
.dash-hero-txt{min-width:0;flex:1}
.hero-greet{font-size:13px;opacity:.92;font-weight:500;letter-spacing:.02em}
.hero-greet b{font-weight:800}
.dash-hero h1{font-size:22px;margin-top:2px}
.hero-occ{margin-left:auto;align-self:stretch;display:flex;flex-direction:column;justify-content:center;text-align:center;
  padding:4px 4px 4px 20px;border-left:1px solid rgba(255,255,255,.22);min-width:150px}
.hero-occ-val{font-size:32px;font-weight:800;line-height:1}
.hero-occ-val span{font-size:17px;font-weight:700;opacity:.85;margin-left:1px}
.hero-occ-lbl{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;opacity:.85;margin-top:4px}
.hero-occ-bar{height:6px;border-radius:6px;background:rgba(255,255,255,.22);margin-top:9px;overflow:hidden}
.hero-occ-bar span{display:block;height:100%;border-radius:6px;background:#fff;box-shadow:0 0 10px rgba(255,255,255,.55);transition:width .8s cubic-bezier(.2,.8,.2,1)}
.hero-occ-sub{font-size:11px;opacity:.8;margin-top:6px}
@media(max-width:820px){.hero-occ{display:none}}

.dash-cards .kpi .val{white-space:nowrap}

.dash-panels .panel{padding:0;overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line)}
.panel-title{display:flex;align-items:center;gap:11px;font-weight:700;font-size:14px;color:#0f172a}
.panel-ic{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;flex:0 0 30px;box-shadow:0 4px 10px rgba(16,24,40,.14)}
.panel-ic svg{width:17px;height:17px}
.panel-ic.blue{background:linear-gradient(135deg,#60a5fa,#2563eb)}
.panel-ic.red{background:linear-gradient(135deg,#fb7185,#e11d48)}
.panel .tbl-clean{border:0;border-radius:0;box-shadow:none}
.panel .tbl-clean th{background:#f8fafc}
.panel .tbl-clean td,.panel .tbl-clean th{padding:11px 18px}
.panel .tbl-clean tbody tr:last-child td{border-bottom:0}

/* Avatar de l'utilisateur connecté dans le header */
.u-avatar{width:34px;height:34px;border-radius:50%;flex:0 0 34px;display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;color:#fff;background:linear-gradient(135deg,#3b82f6,#1d4ed8);overflow:hidden;box-shadow:0 2px 6px rgba(37,99,235,.32)}
.u-avatar img{width:100%;height:100%;object-fit:cover}

/* ============================================================
   STOCKS — bandeau brouillons & cartes statistiques
   ============================================================ */
.draft-band{background:#fffbeb;border:1px solid #fde68a;border-left:4px solid #f59e0b;border-radius:14px;padding:12px 14px;margin-bottom:16px}
.draft-band-head{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:#92400e;font-size:13.5px}
.draft-band table{border:0;border-radius:8px}
.draft-band th{background:#fef3c7;color:#92400e}

.stat-card{display:flex;align-items:flex-start;gap:14px;position:relative;overflow:hidden}
.stat-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px}
.stat-ic{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;color:#fff;flex:0 0 46px;box-shadow:0 6px 16px rgba(16,24,40,.16)}
.stat-ic svg{width:23px;height:23px}
.stat-body{min-width:0;flex:1}
.stat-title{font-weight:700;font-size:14px;color:#0f172a;margin-bottom:8px}
.stat-kpis{display:flex;flex-wrap:wrap;gap:14px}
.stat-kpis>div{display:flex;flex-direction:column;line-height:1.1}
.stat-kpis .k{font-size:20px;font-weight:800;color:#0f172a;letter-spacing:-.02em}
.stat-kpis .k.danger{color:#dc2626}
.stat-kpis .l{font-size:11px;color:#94a3b8;text-transform:uppercase;letter-spacing:.03em;margin-top:2px}
.s-emerald::before{background:#059669} .s-emerald .stat-ic{background:linear-gradient(135deg,#34d399,#047857)}
.s-blue::before{background:#2563eb}    .s-blue .stat-ic{background:linear-gradient(135deg,#60a5fa,#1d4ed8)}

/* Statistiques : cartes-vues sélectionnables (une seule vue affichée) */
.stat-pick a.stat-card{text-decoration:none;cursor:pointer;transition:transform .14s,box-shadow .18s,border-color .18s;opacity:.78}
.stat-pick a.stat-card:hover{transform:translateY(-2px);opacity:1}
.stat-pick a.stat-card.on{opacity:1}
.stat-pick a.stat-card.s-emerald.on{border-color:#34d399;box-shadow:0 0 0 3px rgba(16,185,129,.18),0 10px 26px rgba(16,24,40,.06)}
.stat-pick a.stat-card.s-blue.on{border-color:#60a5fa;box-shadow:0 0 0 3px rgba(37,99,235,.18),0 10px 26px rgba(16,24,40,.06)}


/* Contrôle de stock à la vente (paramètres) */
.stock-ctrl{border:1px solid var(--line);border-radius:14px;padding:14px 16px;background:#f8fafc}
.switch-row{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:13.5px;cursor:pointer}
.switch-row input{width:18px;height:18px;flex:0 0 18px;cursor:pointer}
.switch-row span{color:#334155}

/* Purge sélective (paramètres) */
.purge-card{border:1px solid #fecaca;background:#fef2f2;margin-top:18px}
.btn.danger{background:#dc2626;border-color:#dc2626;color:#fff}
.btn.danger:hover{background:#b91c1c;border-color:#b91c1c}

/* Note explicative (paramètres) */
.info-note{display:flex;gap:10px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px;padding:12px 14px}
.info-note>svg{flex:0 0 18px;margin-top:2px}
.info-note b{color:#1e3a8a}
.info-note ul{margin:6px 0 6px 0;padding-left:18px}
.info-note li{font-size:12.8px;color:#334155;margin:3px 0;line-height:1.45}
.info-note .muted{font-size:12px;display:block;margin-top:4px}

/* ============================================================
   MODAL RÉSERVATION — style professionnel
   ============================================================ */
.res-modal{max-width:1300px;width:97vw;padding:0;overflow:hidden}
.res-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 24px;background:linear-gradient(135deg,#1e3a8a,#2563eb);color:#fff}
.res-modal-title{font-size:18px;font-weight:700;letter-spacing:-.01em}
.res-modal-sub{font-size:12.5px;opacity:.85;margin-top:2px}
.res-modal-head .modal-x{color:#fff;opacity:.85;background:rgba(255,255,255,.12);border-radius:8px}
.res-modal-head .modal-x:hover{opacity:1;background:rgba(255,255,255,.22)}
.res-form{padding:14px 24px 18px;max-height:90vh;overflow:auto}
.res-section{margin-bottom:11px}
.res-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b;margin-bottom:7px;padding-bottom:4px;border-bottom:1px solid var(--line)}
.res-form .opt{font-weight:400;color:#94a3b8;font-size:11px}
.res-form .row{gap:12px}
.res-form .field{margin:0}
.res-form .row.mt{margin-top:9px}
.res-summary{background:linear-gradient(135deg,#eff6ff,#f5f9ff);border:1px solid #dbeafe;border-radius:14px;padding:12px 18px;margin:2px 0 8px}
.res-summary-main{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.res-summary-line{font-size:13px;color:#334155}
.res-occ{color:#64748b;font-size:12px}
.res-summary-total{display:flex;align-items:baseline;gap:8px;font-size:12.5px;color:#64748b;font-weight:600}
.res-summary-total b{font-size:22px;color:#1d4ed8;font-weight:800;letter-spacing:-.02em}
.res-summary-sub{font-size:12.5px;color:#64748b;font-weight:600;white-space:nowrap}
.res-summary-sub b{font-size:15px;color:#334155}
.res-summary-meta{font-size:11.5px;color:#94a3b8;margin-top:5px}
.res-summary-meta b{color:#475569}
.res-avail{border-radius:10px;padding:9px 14px;font-size:13px;font-weight:600;margin-bottom:4px}
.res-foot{display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--line);padding-top:13px;margin-top:2px}
.res-foot .btn{min-width:130px}
.res-form input[type=date]{max-width:175px}
.res-form .field.dt{flex:0 1 175px}
