:root{color-scheme:light;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;background-color:#f5f6f8;color:#0f172a}*{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:#f5f6f8}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit;border:none;background:none;cursor:pointer}.app-shell{display:flex;min-height:100vh;background-color:#f5f6f8}.sidebar{width:260px;background:linear-gradient(180deg,#0f172a,#1e293b);color:#f8fafc;display:flex;flex-direction:column;padding:32px 24px}.sidebar-logo{font-size:1.5rem;font-weight:700;margin-bottom:24px}.sidebar-subtitle{font-size:.85rem;color:#f8fafca6;margin-bottom:28px}.sidebar-nav{display:flex;flex-direction:column;gap:8px}.nav-link{padding:10px 14px;border-radius:10px;font-weight:500;color:#f8fafcbf;transition:background-color .2s ease,color .2s ease}.nav-link:hover{background-color:#0f172a80;color:#f8fafc}.nav-link-active{background-color:#f8fafc1f;color:#fff}.sidebar-footer{margin-top:auto;padding-top:20px;border-top:1px solid rgba(248,250,252,.15);display:flex;flex-direction:column;gap:12px}.user-pill{display:flex;flex-direction:column;gap:4px}.user-pill-name{font-weight:600}.user-pill-email{font-size:.8rem;color:#f8fafc99}.signout-button{align-self:flex-start;padding:8px 14px;border-radius:8px;background-color:#f8fafc1f;color:#f8fafc;font-weight:500;transition:background-color .2s ease}.signout-button:hover{background-color:#f8fafc33}.content{flex:1;padding:32px 40px;display:flex;flex-direction:column;gap:24px}.content-header{display:flex;align-items:center;justify-content:space-between}.content-title{font-size:1.75rem;font-weight:700}.content-description{color:#475569;margin-top:4px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.summary-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 12px 30px #0f172a1a;display:flex;flex-direction:column;gap:12px}.summary-card-title{font-size:.95rem;color:#64748b}.summary-card-value{font-size:2rem;font-weight:700;color:#0f172a}.panel{background:#fff;border-radius:16px;padding:24px;box-shadow:0 12px 30px #0f172a14}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.panel-title{font-size:1.1rem;font-weight:600}.panel-description{color:#64748b;font-size:.95rem}table{width:100%;border-collapse:collapse}thead{background-color:#f1f5f9;text-align:left;font-size:.85rem;color:#475569}thead th{padding:12px 16px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}tbody td{padding:14px 16px;border-bottom:1px solid #e2e8f0}tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:capitalize;background-color:#e0f2fe;color:#0c4a6e}.table-link{color:#2563eb;font-weight:500}.loading-state,.error-state,.empty-state{padding:24px;text-align:center;color:#475569}.signin-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top left,#e0f2fe,transparent 60%),radial-gradient(circle at bottom right,#ede9fe,transparent 55%),#f5f6f8;padding:24px}.signin-card{background:#fff;border-radius:20px;padding:32px;max-width:420px;width:100%;box-shadow:0 18px 45px #0f172a1a;display:flex;flex-direction:column;gap:20px;text-align:center}.signin-title{font-size:1.75rem;font-weight:700;margin:0}.signin-description{color:#475569;margin:0}.google-button{display:inline-flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:12px 18px;border-radius:12px;background-color:#0f172a;color:#f8fafc;font-weight:600;font-size:1rem;transition:transform .2s ease,box-shadow .2s ease}.google-button:hover{transform:translateY(-1px);box-shadow:0 12px 25px #0f172a2e}.google-icon{width:20px;height:20px}.signin-error{background:#fee2e2;color:#991b1b;padding:10px 14px;border-radius:10px;font-size:.9rem}.family-detail-grid{display:grid;gap:20px}.member-table{margin-top:12px;border-radius:12px;overflow:hidden;box-shadow:0 8px 20px #0f172a14}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.stat-card{background:#fff;border-radius:14px;padding:18px;box-shadow:0 12px 28px #0f172a14}.stat-label{font-size:.85rem;color:#64748b}.stat-value{font-size:1.6rem;font-weight:700;margin-top:6px}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.9rem;color:#475569}.breadcrumb a{color:#2563eb}@media (max-width: 960px){.app-shell{flex-direction:column}.sidebar{width:100%;flex-direction:row;align-items:center;justify-content:space-between;gap:24px}.sidebar-nav{flex-direction:row;gap:12px}.sidebar-footer{border-top:none;padding-top:0;flex-direction:row;align-items:center;gap:16px}.content{padding:24px}}
