:root{--bleu-900:#172554;--bleu-700:#1d4ed8;--bleu-600:#2563eb;--bleu-100:#dbeafe;--bleu-50:#eff6ff;--ambre-600:#d97706;--ambre-100:#fef3c7;--vert-600:#059669;--vert-100:#d1fae5;--rouge-600:#dc2626;--rouge-100:#fee2e2;--slate-900:#0f172a;--slate-700:#334155;--slate-500:#64748b;--slate-400:#94a3b8;--slate-300:#cbd5e1;--slate-200:#e2e8f0;--slate-100:#f1f5f9;--slate-50:#f8fafc;--blanc:#fff;--primary:var(--bleu-600);--primary-fort:var(--bleu-700);--texte:var(--slate-900);--texte-doux:var(--slate-500);--bord:var(--slate-200);--fond:var(--slate-100);--surface:var(--blanc);--radius:12px;--radius-sm:8px;--ombre-sm:0 1px 2px #0f172a0f, 0 1px 3px #0f172a14;--ombre:0 4px 6px -1px #0f172a14, 0 2px 4px -2px #0f172a0f;--ombre-lg:0 20px 25px -5px #0f172a1f, 0 8px 10px -6px #0f172a14;--font:"Fira Sans", "Segoe UI", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{font-family:var(--font);color:var(--texte);background:var(--fond);-webkit-font-smoothing:antialiased;margin:0;font-size:15px;line-height:1.5}h1,h2,h3,h4{color:var(--slate-900);margin:0;line-height:1.25}p{margin:0}:focus-visible{outline:3px solid var(--bleu-700);outline-offset:2px;border-radius:4px}@media (prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important}}.btn{border-radius:var(--radius-sm);min-height:44px;font:inherit;cursor:pointer;white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:0 18px;font-weight:600;transition:background .15s,border-color .15s,box-shadow .15s,transform 50ms;display:inline-flex}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-fort)}.btn-ghost{background:var(--surface);color:var(--slate-700);border-color:var(--bord)}.btn-ghost:hover:not(:disabled){background:var(--slate-50);border-color:var(--slate-300)}.btn-danger{background:var(--rouge-600);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-sm{min-height:36px;padding:0 12px;font-size:14px}.btn-icon{min-width:40px;min-height:40px;padding:0 10px}.btn-block{width:100%}.field{flex-direction:column;gap:6px;display:flex}.field label{color:var(--slate-700);font-size:13.5px;font-weight:600}.field .hint{color:var(--texte-doux);font-size:12.5px}.input,.select,textarea.input{border:1px solid var(--slate-300);border-radius:var(--radius-sm);min-height:44px;font:inherit;color:var(--texte);background:var(--surface);width:100%;padding:10px 12px}textarea.input{resize:vertical;min-height:80px}.input:focus,.select:focus,textarea.input:focus{border-color:var(--primary)}.input::placeholder{color:var(--slate-400)}.grid-2{grid-template-columns:1fr 1fr;gap:14px;display:grid}@media (width<=540px){.grid-2{grid-template-columns:1fr}}.card{background:var(--surface);border:1px solid var(--bord);border-radius:var(--radius);box-shadow:var(--ombre-sm)}.card-pad{padding:18px}.badge{border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:12.5px;font-weight:600;line-height:1.4;display:inline-flex}.badge-active{background:var(--bleu-100);color:var(--bleu-900)}.badge-completed{background:var(--vert-100);color:#065f46}.badge-cancelled{background:var(--slate-200);color:var(--slate-700)}.badge-admin{background:var(--ambre-100);color:#92400e}.badge-volunteer{background:var(--slate-100);color:var(--slate-700)}.badge-muted{background:var(--slate-100);color:var(--slate-500)}.table-wrap{overflow-x:auto}table.tbl{border-collapse:collapse;width:100%;font-size:14.5px}.tbl th{text-align:left;text-transform:uppercase;letter-spacing:.03em;color:var(--texte-doux);border-bottom:1px solid var(--bord);white-space:nowrap;padding:10px 12px;font-size:12.5px}.tbl td{border-bottom:1px solid var(--slate-100);vertical-align:middle;padding:12px}.tbl tr:last-child td{border-bottom:none}.tbl tbody tr.clickable{cursor:pointer}.tbl tbody tr.clickable:hover{background:var(--bleu-50)}.shell{flex-direction:column;min-height:100vh;display:flex}.topbar{z-index:20;background:var(--surface);border-bottom:1px solid var(--bord);align-items:center;gap:16px;height:64px;padding:0 20px;display:flex;position:sticky;top:0}.brand{color:var(--bleu-900);align-items:center;gap:12px;font-weight:800;display:flex}.brand .logo{background:linear-gradient(135deg, var(--bleu-600), var(--bleu-900));color:#fff;border-radius:10px;place-items:center;width:38px;height:38px;font-size:18px;font-weight:800;display:grid}.brand .sub{color:var(--texte-doux);font-size:12px;font-weight:500}.topbar-spacer{flex:1}.usermenu{position:relative}.usermenu .who{text-align:right;line-height:1.2}.usermenu .who .name{font-size:14px;font-weight:700}.usermenu .who .role{color:var(--texte-doux);font-size:12px}.menu-pop{background:var(--surface);border:1px solid var(--bord);border-radius:var(--radius);box-shadow:var(--ombre-lg);z-index:30;min-width:210px;padding:6px;position:absolute;top:calc(100% + 8px);right:0}.menu-pop button{border-radius:var(--radius-sm);width:100%;font:inherit;color:var(--slate-700);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:10px 12px;display:flex}.menu-pop button:hover{background:var(--slate-50)}.layout{flex:1;display:flex}.nav{border-right:1px solid var(--bord);background:var(--surface);flex-shrink:0;width:230px;padding:16px 12px}.nav a,.nav button.navitem{border-radius:var(--radius-sm);width:100%;color:var(--slate-700);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:11px;margin-bottom:4px;padding:11px 13px;font-family:inherit;font-size:14.5px;font-weight:600;display:flex}.nav button.navitem:hover{background:var(--slate-50)}.nav button.navitem.active{background:var(--bleu-50);color:var(--bleu-700)}.nav .navicon{justify-content:center;align-items:center;width:22px;display:inline-flex}.content{flex:1;width:100%;max-width:1180px;margin:0 auto;padding:24px}.page-head{flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:20px;display:flex}.page-head h1{font-size:22px}.page-head .grow{flex:1}.nav-toggle{display:none}@media (width<=820px){.layout{flex-direction:column}.nav{border-right:none;border-bottom:1px solid var(--bord);gap:6px;width:100%;padding:10px 12px;display:flex;overflow-x:auto}.nav a,.nav button.navitem{white-space:nowrap;width:auto;margin-bottom:0}.content{padding:16px}}.tiles{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;display:grid}.tile{padding:18px}.tile .tile-label{color:var(--texte-doux);font-size:13px;font-weight:600}.tile .tile-value{margin-top:6px;font-size:26px;font-weight:800}.tile .tile-sub{color:var(--texte-doux);margin-top:4px;font-size:13px}.pledge-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.pledge-card{cursor:pointer;gap:16px;padding:18px;transition:box-shadow .15s,border-color .15s;display:flex}.pledge-card:hover{box-shadow:var(--ombre);border-color:var(--slate-300)}.pledge-card .info{flex:1;min-width:0}.pledge-card .donor{font-size:16px;font-weight:700}.pledge-card .meta{color:var(--texte-doux);margin-top:2px;font-size:13px}.pledge-card .amounts{margin-top:12px;font-size:13.5px}.pledge-card .amounts .restant{color:var(--slate-900);font-weight:700}.ring{flex-shrink:0;position:relative}.ring .ring-label{color:var(--slate-900);place-items:center;font-size:14px;font-weight:800;display:grid;position:absolute;inset:0}.overlay{z-index:50;background:#0f172a80;place-items:center;padding:16px;animation:.15s fade;display:grid;position:fixed;inset:0}@keyframes fade{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--ombre-lg);flex-direction:column;width:100%;max-width:560px;max-height:90vh;display:flex}.modal.wide{max-width:720px}.modal-head{border-bottom:1px solid var(--bord);align-items:center;padding:18px 20px;display:flex}.modal-head h2{flex:1;font-size:18px}.modal-body{padding:20px;overflow-y:auto}.modal-foot{border-top:1px solid var(--bord);justify-content:flex-end;gap:10px;padding:16px 20px;display:flex}.modal .close{cursor:pointer;color:var(--slate-500);background:0 0;border:none;border-radius:6px;padding:6px;font-size:22px;line-height:1}.modal .close:hover{background:var(--slate-100)}.form-stack{flex-direction:column;gap:14px;display:flex}.toasts{z-index:80;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}.toast{border-radius:var(--radius);color:#fff;box-shadow:var(--ombre-lg);padding:12px 18px;font-weight:600;animation:.2s pop}@keyframes pop{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.toast-success{background:var(--vert-600)}.toast-error{background:var(--rouge-600)}.toast-info{background:var(--slate-700)}.empty{text-align:center;color:var(--texte-doux);padding:48px 20px}.empty-icon{background:var(--slate-100);width:64px;height:64px;color:var(--slate-400);border-radius:50%;place-items:center;margin:0 auto;display:grid}.spinner{border:3px solid var(--slate-200);border-top-color:var(--primary);border-radius:50%;width:34px;height:34px;margin:40px auto;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.banner-error{background:var(--rouge-100);color:#991b1b;border-radius:var(--radius-sm);border:1px solid #fca5a5;padding:11px 14px;font-size:14px;font-weight:600}.banner-info{background:var(--bleu-50);color:var(--bleu-900);border:1px solid var(--bleu-100);border-radius:var(--radius-sm);padding:11px 14px;font-size:14px}.login-wrap{background:radial-gradient(1200px 500px at 50% -10%, var(--bleu-100), var(--fond));place-items:center;min-height:100vh;padding:20px;display:grid}.login-card{width:100%;max-width:410px;padding:32px}.login-card .brand{text-align:center;flex-direction:column;justify-content:center;margin-bottom:8px}.login-card .brand .logo{width:54px;height:54px;font-size:24px}.login-card h1{text-align:center;margin:14px 0 4px;font-size:20px}.login-card .tagline{text-align:center;color:var(--texte-doux);margin-bottom:22px;font-size:14px}.row-actions{gap:8px;display:flex}.text-muted{color:var(--texte-doux)}.mono{font-family:ui-monospace,Cascadia Code,Consolas,monospace}.nowrap{white-space:nowrap}.flex{align-items:center;gap:10px;display:flex}.flex-wrap{flex-wrap:wrap}.gap-sm{gap:6px}.mt{margin-top:16px}.divider{background:var(--bord);height:1px;margin:16px 0}
