*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue: #1e3a5f;--blue-lt: #2563a8;--green: #1a6b3a;--gray: #64748b;--gray-lt: #f1f5f9;--border: #e2e8f0;--radius: 10px}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:#f5f7fa;color:#1e293b;min-height:100vh;font-size:14px}.header{background:var(--blue);color:#fff;padding:0 24px;position:sticky;top:0;z-index:100;box-shadow:0 1px 8px #0000002e}.header-inner{max-width:1200px;margin:0 auto;height:64px;display:flex;align-items:center;justify-content:space-between;gap:16px}.header-brand{display:flex;align-items:center;gap:12px}.brand-logo{width:36px;height:36px;background:#ffffff26;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;letter-spacing:-.5px;flex-shrink:0}.header-title{font-size:1.05rem;font-weight:700}.header-date{font-size:.75rem;opacity:.65;margin-top:2px;text-transform:capitalize}.date-nav{display:flex;align-items:center;gap:6px}.btn-nav{width:32px;height:32px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:6px;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;line-height:1;padding-bottom:1px}.btn-nav:hover{background:#fff3}.date-input{height:32px;padding:0 8px;border-radius:6px;border:1px solid rgba(255,255,255,.25);background:#ffffff1a;color:#fff;font-size:.85rem;cursor:pointer}.date-input::-webkit-calendar-picker-indicator{filter:invert(1);opacity:.7}.btn-today{height:32px;padding:0 12px;border-radius:6px;border:1px solid rgba(255,255,255,.3);background:#ffffff1f;color:#fff;font-size:.78rem;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}.btn-today:hover{background:#ffffff38}.main{max-width:1200px;margin:24px auto;padding:0 20px}.state-center{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--gray);gap:12px}.state-center.empty{font-size:.95rem}.spinner{width:26px;height:26px;border:3px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.alert{padding:12px 16px;border-radius:var(--radius);margin-bottom:16px;font-size:.88rem}.alert-error{background:#fef2f2;color:#991b1b;border-left:3px solid #dc2626}.stat-cards{display:flex;gap:12px;margin-bottom:24px}.stat-card{background:#fff;border-radius:var(--radius);padding:16px 20px;box-shadow:0 1px 3px #0000000f;flex:1;border-top:3px solid transparent}.stat-total{border-top-color:var(--blue)}.stat-present{border-top-color:var(--green)}.stat-parti{border-top-color:var(--gray)}.stat-num{display:block;font-size:2rem;font-weight:800;line-height:1}.stat-total .stat-num{color:var(--blue)}.stat-present .stat-num{color:var(--green)}.stat-parti .stat-num{color:var(--gray)}.stat-label{display:block;font-size:.75rem;color:var(--gray);margin-top:4px;font-weight:500}.section{margin-bottom:28px}.section-header{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;border-radius:var(--radius) var(--radius) 0 0;border-bottom:1px solid var(--border);box-shadow:0 1px 3px #0000000f}.section-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot--present{background:var(--green)}.dot--parti{background:var(--gray)}.section-title{font-size:.9rem;font-weight:700}.section-count{margin-left:auto;background:var(--gray-lt);color:var(--gray);border-radius:20px;padding:2px 10px;font-size:.75rem;font-weight:600}.table-wrapper{overflow-x:auto}.table{width:100%;border-collapse:collapse;background:#fff;border-radius:0 0 var(--radius) var(--radius);box-shadow:0 1px 3px #0000000f}.table th{text-align:left;padding:9px 16px;font-size:.72rem;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:.5px;background:#fafbfc;border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:11px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.table-row:last-child td{border-bottom:none}.table-row:hover td{background:#f8fafc}.person{display:flex;align-items:center;gap:10px}.avatar{width:32px;height:32px;border-radius:50%;background:var(--blue);color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:.5px}.person-name{font-weight:600;font-size:.88rem}.person-sub{font-size:.73rem;color:var(--gray);margin-top:1px}.cell-time{font-variant-numeric:tabular-nums;font-size:.88rem;color:#334155;white-space:nowrap}.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:.72rem;font-weight:600}.badge--fait{background:#dcfce7;color:#15803d}.badge--faire{background:#fef9c3;color:#a16207}.badge--sans{background:var(--gray-lt);color:var(--gray)}.badge--type{font-weight:500}.badge--int{background:#eff6ff;color:#1d4ed8}.badge--vis{background:#f5f3ff;color:#6d28d9}@media (max-width: 640px){.header-inner{height:auto;padding:12px 0;flex-direction:column;align-items:flex-start;gap:10px}.header{padding:12px 16px;position:static}.main{margin:16px auto;padding:0 12px}.stat-cards{gap:8px}.stat-card{padding:12px 14px}.stat-num{font-size:1.6rem}.col-hide-sm{display:none}.table th,.table td,.section-header{padding:10px 12px}.avatar{width:28px;height:28px;font-size:.65rem}}
