:root{
  --teal:#00A096; --teal-dark:#00534C; --teal-soft:#E4F3F1;
  --amber:#F8B334; --gold:#B47B0A; --orange:#E7511E; --bordeaux:#9B2E1A;
  --dark:#494C4A; --text:#2E2F2D; --text-soft:#7A7C79;
  --bg:#F7F6F5; --white:#fff; --grey-light:#EBEBEA; --grey-mid:#D6D5D3;
  --ok:#1f9d6b; --shadow:0 5px 24px rgba(73,76,74,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Outfit',system-ui,sans-serif;color:var(--text);background:var(--bg);font-size:14px;line-height:1.5}
a{color:inherit;text-decoration:none}
.topstrip{height:5px;background:linear-gradient(90deg,var(--amber) 0%,var(--orange) 28%,var(--teal) 60%,var(--teal-dark) 100%)}

/* ---------------- layout shell ---------------- */
.shell{display:flex;min-height:calc(100vh - 5px)}
.side{width:248px;flex-shrink:0;background:var(--white);border-right:1px solid var(--grey-light);
      display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.brand{padding:22px 20px 16px;border-bottom:1px solid var(--grey-light)}
.brand img{height:40px;display:block}
.brand-sub{display:block;margin-top:10px;font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-soft)}
.nav{flex:1;padding:14px 10px;display:flex;flex-direction:column;gap:3px;overflow-y:auto}
.nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;font-size:13.5px;font-weight:500;color:var(--text-soft);transition:.12s}
.nav a svg{width:18px;height:18px;flex-shrink:0}
.nav a:hover{background:var(--bg);color:var(--dark)}
.nav a.on{background:var(--teal-soft);color:var(--teal-dark);font-weight:600}
.nav a.on svg{color:var(--teal)}
.side-foot{display:flex;align-items:center;gap:10px;padding:14px;border-top:1px solid var(--grey-light)}
.ava{width:34px;height:34px;border-radius:50%;background:var(--teal-soft);color:var(--teal-dark);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}
.who{flex:1;min-width:0;line-height:1.25}
.who b{display:block;font-size:12.5px;color:var(--dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.who span{font-size:11px;color:var(--text-soft)}
.out{color:var(--text-soft);padding:6px;border-radius:8px}.out:hover{background:var(--bg);color:var(--orange)}.out svg{width:18px;height:18px;display:block}
.ops{display:flex;align-items:center;gap:7px;padding:12px 16px;border-top:1px solid var(--grey-light);color:var(--grey-mid);transition:.15s}
.ops:hover{background:var(--bg)}
.ops span{font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-soft)}
.ops img{height:15px;opacity:.85}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.content{padding:34px 40px 48px;max-width:1180px;width:100%;animation:fadeup .35s ease}

/* ---------------- barre mobile + drawer ---------------- */
.topbar{display:none;align-items:center;gap:12px;padding:9px 14px;background:var(--white);border-bottom:1px solid var(--grey-light);position:sticky;top:0;z-index:30}
.topbar .burger{border:1px solid var(--grey-mid);background:#fff;border-radius:10px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--dark);transition:.12s}
.topbar .burger:hover{background:var(--bg)}
.topbar .tb-logo{height:28px}
.topbar .tb-out{margin-left:auto;color:var(--text-soft);padding:8px;border-radius:9px}
.topbar .tb-out:hover{background:var(--bg);color:var(--orange)}
.topbar .burger svg,.topbar .tb-out svg{width:20px;height:20px}
.scrim{position:fixed;inset:0;background:rgba(40,42,40,.42);z-index:40;opacity:0;transition:opacity .2s}
.scrim.show{opacity:1}
@keyframes fadeup{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------------- page head ---------------- */
.eyebrow{font-size:11px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--teal)}
h1{font-family:'DM Serif Display',serif;font-weight:400;font-size:30px;color:var(--dark);margin:6px 0 4px}
.lead{color:var(--text-soft);max-width:760px;margin-bottom:24px}
h2{font-family:'DM Serif Display',serif;font-weight:400;font-size:20px;color:var(--dark);margin:0}

/* ---------------- flash ---------------- */
.flash{padding:12px 16px;border-radius:11px;margin-bottom:16px;font-size:13.5px;font-weight:500;border-left:4px solid}
.flash.success{background:var(--teal-soft);color:var(--teal-dark);border-color:var(--teal)}
.flash.error{background:#FBE7DD;color:var(--bordeaux);border-color:var(--orange)}

/* ---------------- cards ---------------- */
.card{background:var(--white);border:1px solid var(--grey-light);border-radius:15px;padding:22px;box-shadow:var(--shadow)}
.cards{display:grid;gap:14px}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:24px}
.kpi{background:var(--white);border:1px solid var(--grey-light);border-radius:14px;padding:16px 18px;box-shadow:var(--shadow)}
.kpi .v{font-family:'DM Serif Display',serif;font-size:28px;color:var(--teal-dark);line-height:1}
.kpi .l{font-size:11.5px;color:var(--text-soft);margin-top:8px;font-weight:500}

/* ---------------- buttons ---------------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:inherit;font-size:13.5px;font-weight:600;
     padding:11px 20px;border-radius:10px;border:1px solid transparent;cursor:pointer;transition:.12s}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--teal);color:#fff}.btn-primary:hover{background:var(--teal-dark)}
.btn-ghost{background:var(--white);border-color:var(--grey-mid);color:var(--dark)}.btn-ghost:hover{background:var(--bg)}
.btn-warn{background:var(--orange);color:#fff}.btn-warn:hover{filter:brightness(.94)}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* ---------------- progress (ring + bars) ---------------- */
.ring{--p:0;width:96px;height:96px;border-radius:50%;flex-shrink:0;
      background:conic-gradient(var(--teal) calc(var(--p)*1%), var(--grey-light) 0);
      display:flex;align-items:center;justify-content:center}
.ring i{width:74px;height:74px;border-radius:50%;background:var(--white);display:flex;align-items:center;justify-content:center;
        font-family:'DM Serif Display',serif;font-size:22px;color:var(--teal-dark);font-style:normal}
.bar{height:7px;border-radius:6px;background:var(--grey-light);overflow:hidden}
.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--amber));border-radius:6px;transition:width .3s}

/* ---------------- section cards (AGC home) ---------------- */
.seclist{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;margin-top:8px}
.seccard{background:var(--white);border:1px solid var(--grey-light);border-radius:14px;padding:18px;box-shadow:var(--shadow);
         display:flex;flex-direction:column;gap:12px;transition:.12s}
.seccard:hover{border-color:var(--teal);transform:translateY(-2px)}
.seccard .top{display:flex;align-items:center;gap:12px}
.seccard .ic{width:40px;height:40px;border-radius:11px;background:var(--teal-soft);display:flex;align-items:center;justify-content:center}
.seccard .ic svg{width:20px;height:20px;color:var(--teal)}
.seccard .ti{font-weight:600;font-size:15px;color:var(--dark)}
.seccard .sub{font-size:12px;color:var(--text-soft)}
.seccard .pctline{display:flex;justify-content:space-between;font-size:11.5px;color:var(--text-soft);margin-bottom:5px}
.done-badge{color:var(--ok);font-weight:700;display:inline-flex;align-items:center;gap:4px}
.done-badge svg.lucide{width:14px;height:14px}

/* ---------------- wizard ---------------- */
.wz{display:flex;gap:26px;align-items:flex-start}
.wz-rail{width:230px;flex-shrink:0;position:sticky;top:24px;background:var(--white);border:1px solid var(--grey-light);border-radius:14px;padding:12px;box-shadow:var(--shadow)}
.wz-rail .g{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:13px;font-weight:600;color:var(--teal-dark);padding:10px 12px;background:var(--teal-soft);border-radius:9px;margin-bottom:10px}
.wz-rail a{display:flex;align-items:center;gap:9px;padding:8px 12px;border-radius:8px;font-size:12.5px;color:var(--text-soft);font-weight:500}
.wz-rail a:hover{background:var(--bg);color:var(--dark)}
.wz-rail a.on{background:var(--bg);color:var(--dark);font-weight:600}
.wz-rail a .dot{width:8px;height:8px;border-radius:50%;background:var(--grey-mid);flex-shrink:0}
.wz-rail a .dot.full{background:var(--teal)}.wz-rail a .dot.part{background:var(--amber)}
.wz-main{flex:1;min-width:0}
.fgroup{background:var(--white);border:1px solid var(--grey-light);border-radius:14px;padding:20px 22px;box-shadow:var(--shadow);margin-bottom:16px}
.fgroup h3{font-size:13px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--teal-dark);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--grey-light)}
.frow{display:grid;grid-template-columns:1fr 240px;gap:14px;align-items:center;padding:9px 0;border-bottom:1px dashed var(--grey-light)}
.frow:last-child{border-bottom:none}
.frow label{font-size:13.5px;color:var(--text)}
.frow .unit{font-size:11px;color:var(--text-soft);margin-left:6px}
.frow .req{color:var(--orange)}
.fld{position:relative}
.fld input,.fld textarea{width:100%;font-family:inherit;font-size:13.5px;padding:10px 12px;border:1px solid var(--grey-mid);border-radius:9px;background:var(--white);color:var(--text)}
.fld input:focus,.fld textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft)}
.fld input.saved{border-color:var(--teal)}
.fld .tick{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--ok);opacity:0;transition:.2s;display:inline-flex}
.fld .tick svg.lucide{width:16px;height:16px;display:block}
.fld input.saved + .tick{opacity:1}
.alert{grid-column:1/-1;display:flex;align-items:center;gap:9px;font-size:12.5px;background:rgba(248,179,52,.12);border:1px solid rgba(248,179,52,.4);border-radius:9px;padding:8px 12px;margin-top:4px}
.alert.info{background:var(--teal-soft);border-color:rgba(0,160,150,.3);color:var(--teal-dark)}
.alert .justif{margin-left:auto;font-size:12px;padding:5px 9px;border:1px solid var(--grey-mid);border-radius:8px;width:240px}
.wz-foot{display:flex;justify-content:space-between;align-items:center;margin-top:8px}

/* ---------------- tables (DAF) ---------------- */
.tbl{width:100%;border-collapse:collapse;background:var(--white);border:1px solid var(--grey-light);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.tbl th{text-align:left;background:var(--bg);color:var(--text-soft);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:12px 16px}
.tbl td{padding:11px 16px;border-top:1px solid var(--grey-light);font-size:13.5px}
.tbl tr:hover td{background:#FCFDFD}
.tbl .barmini{width:90px;display:inline-block;vertical-align:middle}
.pill{font-size:10.5px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;border-radius:20px;padding:3px 10px;white-space:nowrap}
.pill.draft{background:var(--grey-light);color:var(--text-soft)}
.pill.submitted{background:rgba(248,179,52,.18);color:var(--gold)}
.pill.validated{background:var(--teal-soft);color:var(--teal-dark)}
.pill.returned{background:#FBE7DD;color:var(--orange)}
.pill.none{background:var(--grey-light);color:var(--grey-mid)}

/* ---------------- login ---------------- */
.auth-wrap{min-height:calc(100vh - 5px);display:flex;align-items:center;justify-content:center;padding:30px;
  background:radial-gradient(800px 460px at 80% -10%,#DCF1EE,transparent),radial-gradient(700px 460px at 0% 120%,#FCEBD2,transparent),var(--bg)}
.auth-card{width:400px;max-width:100%;background:var(--white);border:1px solid var(--grey-light);border-radius:18px;padding:34px 32px;box-shadow:0 30px 60px -24px rgba(0,83,76,.25)}
.auth-card img{height:34px;margin-bottom:22px}
.auth-card h1{font-size:23px;margin:0 0 6px}
.auth-card .lead{font-size:13.5px;margin-bottom:22px}
.auth-card label{display:block;font-size:12px;font-weight:600;color:var(--text-soft);margin:14px 0 6px}
.auth-card input{width:100%;font-family:inherit;font-size:14px;padding:12px 14px;border:1px solid var(--grey-mid);border-radius:10px}
.auth-card input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft)}
.auth-card .btn{width:100%;justify-content:center;margin-top:22px}

.muted{color:var(--text-soft);font-size:12.5px}
.mono{font-family:'DM Mono',monospace;font-size:12px;background:var(--bg);padding:2px 7px;border-radius:5px;color:var(--teal-dark)}
.row-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
form.inline{display:inline}
@media(max-width:900px){
  .wz{flex-direction:column}.wz-rail{width:100%;position:static}.frow{grid-template-columns:1fr}
  .topbar{display:flex}
  .side{position:fixed;top:0;left:0;height:100vh;z-index:50;transform:translateX(-100%);transition:transform .22s ease;box-shadow:0 24px 60px -12px rgba(0,83,76,.35)}
  .side.open{transform:none}
  .content{padding:22px 18px 40px}
}
