html,body,#root{width:100%;min-height:100%}:root{color:#0f172a;background:#f1f5f9;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:15px;line-height:1.5}*{box-sizing:border-box}body{margin:0}.app-shell{min-height:100vh;display:flex}.sidebar{color:#e2e8f0;background:#0f172a;flex-direction:column;flex-shrink:0;width:240px;height:100vh;padding:1.25rem 0;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid #1e293b;margin-bottom:.75rem;padding:0 1.25rem 1.25rem}.sidebar-logo{color:#fff;font-size:1.25rem;font-weight:700;display:block}.sidebar-subtitle{color:#64748b;text-transform:uppercase;letter-spacing:.06em;font-size:.75rem}.sidebar-nav{flex-direction:column;gap:2px;padding:0 .5rem;display:flex}.sidebar-link{color:#94a3b8;border-radius:8px;align-items:center;gap:.6rem;padding:.55rem .75rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.sidebar-link:hover{color:#e2e8f0;background:#1e293b}.sidebar-link-active{color:#fff;background:#1e293b}.sidebar-badge{color:#fff;text-align:center;background:#ef4444;border-radius:10px;min-width:20px;margin-left:auto;padding:.1rem .45rem;font-size:.7rem;font-weight:700}.main-content{flex:1;min-width:0;max-width:1200px;padding:1.5rem 2rem}.page-content{flex-direction:column;gap:1.25rem;display:flex}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.page-header h1{margin:0;font-size:1.5rem;font-weight:700}.page-header-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.page-subtitle{color:#64748b;margin:.15rem 0 0;font-size:.9rem}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:.35rem;font-size:.875rem;font-weight:600;line-height:1;transition:background .15s,box-shadow .15s;display:inline-flex}.btn-md{padding:.55rem 1rem}.btn-sm{padding:.35rem .65rem;font-size:.8rem}.btn-primary{color:#fff;background:#2563eb}.btn-primary:hover{background:#1d4ed8}.btn-secondary{color:#334155;background:#e2e8f0}.btn-secondary:hover{background:#cbd5e1}.btn-danger{color:#fff;background:#ef4444}.btn-danger:hover{background:#dc2626}.btn-ghost{color:#64748b;background:0 0;padding:.35rem}.btn-ghost:hover{color:#0f172a;background:#f1f5f9}.badge{text-transform:capitalize;white-space:nowrap;border-radius:10px;padding:.15rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-blue{color:#1e40af;background:#dbeafe}.badge-green{color:#166534;background:#dcfce7}.badge-yellow{color:#854d0e;background:#fef9c3}.badge-red{color:#991b1b;background:#fee2e2}.badge-gray{color:#475569;background:#f1f5f9}.badge-purple{color:#5b21b6;background:#ede9fe}.badge-orange{color:#9a3412;background:#ffedd5}.modal{border:none;border-radius:14px;width:90vw;max-width:520px;padding:0;box-shadow:0 20px 60px #0003}.modal::backdrop{background:#0f172a73}.modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.modal-header h3{margin:0;font-size:1.1rem}.modal-close{cursor:pointer;color:#64748b;background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1}.modal-body{padding:1.25rem}.modal-actions{justify-content:flex-end;gap:.5rem;margin-top:1rem;display:flex}label{color:#334155;flex-direction:column;gap:.3rem;margin-bottom:.75rem;font-size:.85rem;font-weight:600;display:flex}input,select,textarea{color:#0f172a;background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:.5rem .65rem;font-family:inherit;font-size:.9rem;transition:border-color .15s}input:focus,select:focus,textarea:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb1a}textarea{resize:vertical}.form-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.member-form,.reminder-form,.outreach-form{flex-direction:column;display:flex}.search-bar{background:#fff;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:.5rem;padding:.5rem .75rem;display:flex}.search-bar input{box-shadow:none;border:none;outline:none;flex:1;padding:0;font-size:.9rem}.search-bar svg{color:#94a3b8}.filter-bar{gap:.5rem;display:flex}.filter-bar select{min-width:160px}.table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:#64748b;white-space:nowrap;border-bottom:1px solid #e2e8f0;padding:.75rem 1rem;font-size:.78rem}.data-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:.65rem 1rem}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:#f8fafc}.member-name{font-weight:600}.contact-cell{color:#64748b;font-size:.85rem}.actions-cell{gap:.25rem;display:flex}.status-select{min-width:140px;font-size:.8rem;font-weight:600}.member-selector{min-width:200px}.empty-state{text-align:center;color:#64748b;padding:3rem 1rem}.empty-state-icon{color:#cbd5e1;margin-bottom:.75rem}.empty-state h3{color:#334155;margin:0 0 .35rem}.empty-state p{margin:0;font-size:.9rem}.empty-state-action{margin-top:1rem}.invitation-grid{gap:.75rem;display:grid}.invitation-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.25rem;transition:border-color .15s}.invitation-card:hover{border-color:#cbd5e1}.invitation-card-overdue{border-left:3px solid #ef4444}.invitation-card-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.invitation-card-header>div{align-items:center;gap:.5rem;display:flex}.invitation-card-meta{color:#64748b;align-items:center;gap:.75rem;margin-top:.5rem;font-size:.8rem;display:flex}.invitation-card-meta span{align-items:center;gap:.25rem;display:flex}.overdue-warning{color:#ef4444;font-weight:600}.invitation-card-actions{flex-wrap:wrap;gap:.5rem;margin-top:.75rem;display:flex}.invitation-card-reminders{flex-direction:column;gap:.35rem;margin-top:.75rem;display:flex}.reminder-chip{color:#64748b;background:#f8fafc;border-radius:6px;align-items:center;gap:.35rem;padding:.3rem .6rem;font-size:.78rem;display:flex}.reminder-overdue{color:#dc2626;background:#fef2f2}.timeline-list{flex-direction:column;display:flex}.timeline-entry{border-bottom:1px solid #f1f5f9;gap:.75rem;padding:.85rem 0;display:flex}.timeline-entry:last-child{border-bottom:none}.timeline-icon{color:#2563eb;background:#eff6ff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.timeline-content{flex:1;min-width:0}.timeline-meta{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.timeline-type{color:#64748b;text-transform:capitalize;font-size:.75rem}.timeline-channel{color:#8b5cf6;font-size:.75rem}.timeline-content p{color:#334155;margin:.25rem 0 0;font-size:.9rem}.timeline-content time{color:#94a3b8;font-size:.75rem}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;display:grid}.summary-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.summary-card-icon{flex-shrink:0}.summary-card-value{font-size:1.5rem;font-weight:700;line-height:1.2}.summary-card-label{color:#64748b;font-size:.8rem;font-weight:500}.dashboard-grid{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.chart-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem}.chart-card h3{margin:0 0 1rem;font-size:1rem}.gauge{justify-content:center;margin:1rem 0;display:flex}.gauge-circle{border-radius:50%;justify-content:center;align-items:center;width:160px;height:160px;display:flex}.gauge-inner{background:#fff;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;display:flex}.gauge-value{font-size:2rem;font-weight:700}.gauge-legend{text-align:center;color:#64748b;font-size:.85rem}.gauge-baseline{justify-content:center;align-items:center;gap:.35rem;display:flex}.gauge-baseline-dot{background:#94a3b8;border-radius:50%;width:8px;height:8px}.gauge-status{margin-top:.25rem;font-weight:600}.gauge-above{color:#16a34a}.gauge-below{color:#d97706}.overdue-empty{color:#64748b;font-size:.9rem}.overdue-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.overdue-item{border-bottom:1px solid #f1f5f9;align-items:flex-start;gap:.6rem;padding:.65rem 0;display:flex}.overdue-item:last-child{border-bottom:none}.overdue-icon{color:#ef4444;flex-shrink:0;margin-top:.15rem}.overdue-ago{color:#ef4444;margin-left:.5rem;font-size:.8rem}.overdue-note{color:#64748b;margin:.15rem 0 0;font-size:.85rem}.overdue-link{color:#2563eb;white-space:nowrap;margin-left:auto;font-size:.8rem;text-decoration:none}.overdue-link:hover{text-decoration:underline}.settings-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem}.settings-section h2{margin:0 0 1rem;font-size:1.1rem}.settings-section label{max-width:400px}.settings-actions{flex-wrap:wrap;gap:.75rem;display:flex}@media (width<=768px){.app-shell{flex-direction:column}.sidebar{flex-direction:row;width:100%;height:auto;padding:.75rem;position:static;overflow-x:auto}.sidebar-brand{display:none}.sidebar-nav{flex-direction:row;gap:.25rem;padding:0}.sidebar-link span{display:none}.main-content{padding:1rem}.dashboard-grid,.form-row{grid-template-columns:1fr}}
