.admin{display:flex;min-height:100vh;background:#f1f5f9}.admin-side{width:236px;flex-shrink:0;background:#0f172a;color:#cbd5e1;display:flex;flex-direction:column;padding:16px 14px;position:sticky;top:0;height:100vh;overflow-y:auto}.admin-side .logo{display:flex;align-items:center;gap:10px;color:#fff;font-size:18px;font-weight:700;padding:6px 8px 16px}.admin-side .logo .mark{width:34px;height:34px;border-radius:9px;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff}.admin-side .grp{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#64748b;margin:16px 8px 6px}.admin-nav-item{display:flex;align-items:center;gap:11px;width:100%;padding:10px 12px;border:none;background:none;color:#cbd5e1;border-radius:9px;cursor:pointer;font-size:14px;text-align:left}.admin-nav-item:hover{background:#1e293b;color:#fff}.admin-nav-item.active{background:var(--primary);color:#fff}.admin-nav-item .badge-n{margin-left:auto;background:#dc2626;color:#fff;border-radius:99px;font-size:11px;padding:1px 7px}.admin-side .me{margin-top:auto;display:flex;align-items:center;gap:10px;padding:12px 8px 4px;border-top:1px solid #1e293b}.admin-side .me .av{width:34px;height:34px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px}.admin-main{flex:1;min-width:0;display:flex;flex-direction:column}.admin-top{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 26px;background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:4}.admin-top h1{font-size:20px;margin:0;letter-spacing:-.01em}.admin-top .right{display:flex;align-items:center;gap:12px}.btn-primary{background:var(--primary);color:#fff;border:none;border-radius:10px;padding:9px 14px;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:7px}.btn-primary:hover{background:var(--primary-dark)}.admin-content{padding:22px 26px;display:flex;flex-direction:column;gap:18px}.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.kpi{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px}.kpi .top{display:flex;justify-content:space-between;align-items:flex-start}.kpi .lbl{color:var(--muted);font-size:13px}.kpi .val{font-size:25px;font-weight:700;margin-top:10px;line-height:1.1}.kpi .val small{font-size:13px;color:var(--muted);font-weight:500}.kpi .chip{display:inline-block;margin-top:10px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:99px}.kpi .ic{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center}.two{display:grid;grid-template-columns:1fr 1fr;gap:16px}.wide2{display:grid;grid-template-columns:1.6fr 1fr;gap:16px}.three{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.panel{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px}.panel .ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.panel h3{margin:0;font-size:15px;font-weight:600}.prov{display:flex;align-items:center;gap:14px}.prov .pic{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff}.prov .pct{margin-left:auto;text-align:right}.prov .pct b{font-size:22px}.seg{display:inline-flex;background:#f1f5f9;border-radius:9px;padding:3px;gap:2px}.seg button{border:none;background:none;padding:5px 12px;border-radius:7px;font-size:12px;cursor:pointer;color:var(--muted)}.seg button.on{background:#fff;color:var(--text);font-weight:600;box-shadow:0 1px 2px #0000000f}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl th{text-align:left;color:var(--muted);font-weight:500;font-size:12px;padding:6px 4px;border-bottom:1px solid var(--border)}.tbl td{padding:9px 4px;border-bottom:1px solid #f1f5f9}.op-pill{font-size:11px;font-weight:600;padding:2px 8px;border-radius:99px}.op-pill.OM{background:#fff7ed;color:#c2410c}.op-pill.MoMo{background:#fefce8;color:#a16207}.alert-row{display:flex;gap:10px;padding:9px 0;border-bottom:1px solid #f1f5f9;font-size:13px}.alert-row .dot{width:8px;height:8px;border-radius:50%;background:#dc2626;margin-top:6px;flex-shrink:0}.up-row{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid #f1f5f9}.up-row .date{width:42px;text-align:center}.up-row .date .d{font-size:18px;font-weight:700;line-height:1}.up-row .date .m{font-size:11px;color:var(--muted);text-transform:uppercase}@media (max-width: 1100px){.cards{grid-template-columns:repeat(2,1fr)}.three,.wide2{grid-template-columns:1fr}}@media (max-width: 820px){.admin-side{display:none}.two{grid-template-columns:1fr}}:root{--primary: #0f766e;--primary-dark: #115e59;--primary-soft: #ccfbf1;--accent: #14b8a6;--bg: #f8fafc;--surface: #ffffff;--text: #0f172a;--muted: #64748b;--border: #e2e8f0;--success: #16a34a;--warning: #d97706;--danger: #dc2626;--radius: 16px;--shadow: 0 10px 30px rgba(15, 23, 42, .08);--maxw: 440px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.screen{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 18px calc(24px + env(safe-area-inset-bottom))}.brand{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:22px}.brand img{width:64px;height:64px;border-radius:18px;box-shadow:var(--shadow)}.brand h1{margin:0;font-size:22px;letter-spacing:-.02em}.brand p{margin:0;color:var(--muted);font-size:14px}.card{width:100%;max-width:var(--maxw);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}.card h2{margin:0 0 4px;font-size:19px;letter-spacing:-.01em}.card .sub{margin:0 0 18px;color:var(--muted);font-size:14px}.field{margin-bottom:14px}.field label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}.input{width:100%;height:52px;padding:0 16px;font-size:17px;border:1.5px solid var(--border);border-radius:12px;background:#fff;color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft)}.input.pin{letter-spacing:.4em;text-align:center;font-size:22px}.btn{width:100%;height:52px;border:none;border-radius:12px;background:var(--primary);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:background .15s,transform .05s}.btn:hover{background:var(--primary-dark)}.btn:active{transform:scale(.99)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--muted);height:44px;font-weight:500;margin-top:6px}.btn-ghost:hover{background:#f1f5f9}.alert{background:#fef2f2;border:1px solid #fecaca;color:var(--danger);border-radius:12px;padding:10px 14px;font-size:14px;margin-bottom:14px}.hint{font-size:13px;color:var(--muted);margin-top:2px}.foot{margin-top:18px;color:var(--muted);font-size:12px;text-align:center}.welcome{text-align:center}.welcome .big{font-size:26px;font-weight:700;margin:6px 0}.amount{font-variant-numeric:tabular-nums}.spinner{width:34px;height:34px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app{max-width:480px;margin:0 auto;min-height:100%;padding-bottom:72px}.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:5}.topbar .who{display:flex;align-items:center;gap:12px}.topbar .avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-soft);color:var(--primary-dark);display:flex;align-items:center;justify-content:center;font-weight:600}.topbar .hello{font-size:12px;color:var(--muted)}.topbar .name{font-size:15px;font-weight:600}.selector{border:1px solid var(--border);background:#fff;color:var(--text);border-radius:10px;padding:8px 12px;font-size:13px;font-weight:500;cursor:pointer}.content{padding:16px 18px;display:flex;flex-direction:column;gap:14px}.hero{border-radius:var(--radius);padding:18px;border:1px solid}.hero.ok{background:#ecfdf5;border-color:#a7f3d0}.hero.late{background:#fffbeb;border-color:#fde68a}.hero .tag{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600}.hero.ok .tag{color:var(--success)}.hero.late .tag{color:var(--warning)}.hero .lbl{font-size:13px;color:var(--muted);margin-top:10px}.hero .big{font-size:30px;font-weight:700;line-height:1.1}.hero .big small{font-size:15px;color:var(--muted);font-weight:500}.hero .breakdown{font-size:12px;color:var(--muted);margin-top:4px}.btn-pay{margin-top:14px;width:100%;border:none;border-radius:12px;background:var(--primary);color:#fff;font-size:15px;font-weight:600;padding:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.btn-pay:hover{background:var(--primary-dark)}.btn-pay:disabled{opacity:.55;cursor:not-allowed}.row-card{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:var(--surface)}.row-card .ico{font-size:22px}.row-card .l{font-size:12px;color:var(--muted)}.row-card .v{font-size:14px;font-weight:600}.receive{background:#ecfdf5;border:1px solid #a7f3d0;border-radius:var(--radius);padding:16px;display:flex;align-items:center;gap:14px}.receive .ico{font-size:30px;color:var(--success)}.receive .l{font-size:13px;color:var(--success);font-weight:600}.receive .amt{font-size:21px;font-weight:700}.receive .when{font-size:12px;color:var(--muted)}.progress .head{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:7px}.progress .head b{color:var(--text);font-weight:600}.progress .track{height:9px;background:#e5e7eb;border-radius:99px;overflow:hidden}.progress .fill{height:100%;background:var(--primary);border-radius:99px}.stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stat{background:#f1f5f9;border-radius:12px;padding:12px 14px}.stat .l{font-size:12px;color:var(--muted)}.stat .v{font-size:18px;font-weight:700}.section-title{font-size:15px;font-weight:600;margin:4px 0 2px}.sess{display:flex;flex-direction:column;gap:8px}.sess-row{display:flex;align-items:center;justify-content:space-between;padding:11px 13px;border:1px solid var(--border);border-radius:12px;background:var(--surface)}.sess-row .left{display:flex;align-items:center;gap:11px}.sess-row .ico{font-size:20px}.sess-row .d{font-size:14px;font-weight:600}.sess-row .b{font-size:12px;color:var(--muted)}.badge{font-size:11px;font-weight:600;padding:4px 10px;border-radius:99px;white-space:nowrap}.badge.paye{background:#ecfdf5;color:var(--success)}.badge.a_payer{background:#fffbeb;color:var(--warning)}.badge.a_venir{background:#f1f5f9;color:var(--muted)}.badge.votre_tour{background:#ecfdf5;color:var(--success)}.pay-row{border:1px solid var(--primary);background:var(--primary-soft);color:var(--primary-dark);border-radius:99px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap}.pay-row:hover{background:var(--primary);color:#fff}.bottom-nav{position:fixed;bottom:0;left:0;right:0;max-width:480px;margin:0 auto;display:flex;background:var(--surface);border-top:1px solid var(--border)}.bottom-nav .item{flex:1;text-align:center;padding:9px 0;color:var(--muted);background:none;border:none;cursor:pointer;font-size:11px}.bottom-nav .item .ico{font-size:21px;display:block;line-height:1.4}.bottom-nav .item.active{color:var(--primary)}.notice{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af;border-radius:12px;padding:10px 14px;font-size:13px}
