:root{--color-primary:#047857;--color-primary-dark:#065f46;--color-accent:#d1fae5;--color-background:#f7f3eb}body{background:var(--color-background,#f7f3eb);color:#1f2937;margin:0;font-family:Arial,Helvetica,sans-serif}*{box-sizing:border-box}a{color:inherit;text-decoration:none}code{background:#f3f4f6;border-radius:6px;padding:2px 6px;font-size:.9em}.site-header{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffeb;border-bottom:1px solid #00000014;position:sticky;top:0}.site-header-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;max-width:1100px;margin:0 auto;padding:14px 20px;display:flex}.site-logo{color:#1f3556;font-size:18px;font-weight:700}.site-nav{flex-wrap:wrap;gap:6px;display:flex}.site-nav-link{color:#374151;border-radius:999px;padding:8px 14px;font-size:14px;transition:background .15s}.site-nav-link:hover{background:#f7f3eb}.page{background:var(--color-background,#f7f3eb);min-height:calc(100dvh - 60px);padding:24px 16px}.container{max-width:1100px;margin:0 auto}.header-card{background:#ffffffe0;border:1px solid #0000000f;border-radius:20px;margin-bottom:18px;padding:18px 20px;box-shadow:0 4px 18px #0000000f}.eyebrow{color:var(--color-primary,#047857);letter-spacing:.08em;text-transform:uppercase;margin:0 0 6px;font-size:12px;font-weight:700}.title{color:#111827;margin:0;font-size:28px;line-height:1.1}.subtitle{color:#6b7280;margin:10px 0 0;font-size:16px}.text-muted{color:#6b7280;font-size:15px;line-height:1.5}.card{background:#fff;border:1px solid #0000000f;border-radius:18px;padding:18px;box-shadow:0 4px 16px #0000000f}.card-heading{color:#1f3556;margin:0;font-size:18px}.btn{background:var(--color-primary,#047857);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:9px 16px;font-size:14px;font-weight:700;transition:background .15s;display:inline-block}.btn:hover{background:var(--color-primary-dark,#065f46)}.btn-secondary{color:#1f2937;background:#e5e7eb}.btn-secondary:hover{background:#d1d5db}.btn-small{border-radius:10px;padding:6px 12px;font-size:12px}.btn-light{color:#1f3556;background:#fff}.btn-light:hover{background:#f3f4f6}.btn-outline-light{color:#fff;background:0 0;border:1px solid #ffffff59}.btn-outline-light:hover{background:#ffffff1f}.button{background:var(--color-primary,#047857);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;margin-top:14px;padding:10px 16px;font-size:14px;font-weight:700}.button:hover{background:var(--color-primary-dark,#065f46)}.hero-grid{grid-template-columns:1.3fr .7fr;gap:24px;display:grid}.hero{color:#fff;background:#1f3556;border-radius:28px;padding:32px;box-shadow:0 8px 28px #00000014}.hero-eyebrow{letter-spacing:.08em;text-transform:uppercase;color:#c89b3c;margin:0 0 12px;font-size:13px;font-weight:700}.hero-title{margin:0;font-size:36px;line-height:1.15}.hero-text{color:#ffffffd1;max-width:640px;margin:16px 0 0;line-height:1.6}.hero-actions{flex-wrap:wrap;gap:12px;margin-top:24px;display:flex}.steps-list{color:#374151;margin:16px 0 0;padding-left:20px;font-size:14px;line-height:1.8}.search{background:#fff;border:1px solid #d1d5db;border-radius:18px;outline:none;width:100%;margin-top:22px;padding:14px 16px;font-size:16px}.search:focus{border-color:var(--color-primary,#059669);box-shadow:0 0 0 3px var(--color-accent,#d1fae5)}.family-grid{grid-template-columns:repeat(3,1fr);gap:22px;display:grid}.family-card{background:#fff;border:1px solid #0000000f;border-radius:28px;overflow:hidden;box-shadow:0 8px 22px #0000000f}.card-top{background:linear-gradient(135deg,#d1fae5,#fef3c7);height:110px}.card-body{padding:22px}.family-icon{color:#047857;background:#fff;border:1px solid #0000000f;border-radius:24px;justify-content:center;align-items:center;width:78px;height:78px;margin-top:-62px;margin-bottom:16px;font-size:24px;font-weight:700;display:flex;box-shadow:0 5px 18px #00000014}.family-name{color:#111827;margin:0;font-size:22px}.info{color:#374151;margin:16px 0 0;font-size:15px;line-height:1.5}.info-label{color:#6b7280;font-weight:700}.section{border-top:1px solid #f3f4f6;margin-top:16px;padding-top:14px}.label{color:#6b7280;text-transform:uppercase;letter-spacing:.08em;margin:0;font-size:12px;font-weight:700}.value{color:#111827;margin:5px 0 0;line-height:1.4}.empty-state{text-align:center;color:#6b7280;background:#fff;border:1px dashed #d1d5db;border-radius:24px;padding:40px 24px}.modal-overlay{z-index:200;background:#0f172a9e;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.family-modal-overlay{background:#0a1020b3}.modal{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:#fff;border-radius:28px;width:100%;max-width:520px;max-height:90dvh;padding:28px;position:relative;overflow-y:auto;box-shadow:0 20px 50px #0000002e}.modal-close{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:12px;padding:8px 14px;font-size:13px;font-weight:700;position:absolute;top:16px;right:16px}.modal-close:hover{background:#f3f4f6}.modal-header{margin-bottom:20px;padding-right:80px}.modal-icon{margin-top:0}.modal-title{color:#111827;margin:12px 0 0;font-size:26px}.modal-body{gap:16px;display:grid}.modal-section{border-top:1px solid #f3f4f6;padding-top:14px}.modal-placeholder .value{color:#4b5563}.stat-grid{grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:28px;display:grid}.stat-card{text-align:center}.stat-label{color:#6b7280;text-transform:uppercase;letter-spacing:.06em;margin:0;font-size:13px;font-weight:700}.stat-value{color:#1f3556;margin:10px 0 0;font-size:36px;font-weight:700}.admin-sections{grid-template-columns:repeat(2,1fr);gap:22px;display:grid}.section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.list-plain{margin:16px 0 0;padding:0;list-style:none}.list-plain li{border-bottom:1px solid #f3f4f6;padding:10px 0;font-size:15px;line-height:1.5}.list-plain li:last-child{border-bottom:none}.section-footnote{margin-top:12px;font-size:13px}.settings-placeholder{color:#374151;background:#f9fafb;border-radius:16px;margin:16px 0;padding:16px;font-size:14px;line-height:1.7}.settings-placeholder p{margin:0 0 6px}.profile-form-card{max-width:720px}.login-card{max-width:440px;margin:0 auto}.profile-form{gap:18px;margin-top:8px;display:grid}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group{gap:6px;display:grid}.form-label{color:#374151;font-size:14px;font-weight:700}.form-input,.form-textarea{background:#fff;border:1px solid #d1d5db;border-radius:14px;outline:none;width:100%;padding:12px 14px;font-family:inherit;font-size:15px}.form-input:focus,.form-textarea:focus{border-color:#059669;box-shadow:0 0 0 4px #0596691f}.form-textarea{resize:vertical;min-height:100px}.visibility-fieldset{border:1px solid #e5e7eb;border-radius:16px;margin:0;padding:16px 18px}.visibility-fieldset legend{padding:0 4px}.checkbox-label{color:#374151;align-items:center;gap:10px;margin-top:10px;font-size:14px;display:flex}.checkbox-label:first-of-type{margin-top:4px}.form-checkbox{accent-color:#047857;width:16px;height:16px}.announcement-list{gap:12px;display:grid}.announcement-card{background:#fff;border:1px solid #0000000f;border-radius:12px;padding:14px 16px;box-shadow:0 4px 12px #0000000d}.announcement-meta{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:10px;display:flex}.priority-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:999px;padding:5px 12px;font-size:12px;font-weight:700;display:inline-block}.priority-normal{color:#1f3556;background:#f7f3eb}.priority-important{color:#92400e;background:#fef3c7}.priority-urgent{color:#991b1b;background:#fee2e2}.announcement-date{color:#6b7280;font-size:13px}.announcement-title{color:#1f3556;margin:0;font-size:16px}.announcement-body{color:#374151;margin:12px 0 0;line-height:1.6}.announcement-expires{color:#6b7280;margin:14px 0 0;font-size:13px}.event-list{gap:18px;display:grid}.event-card{background:#fff;border:1px solid #0000000f;border-radius:14px;padding:14px 16px;box-shadow:0 2px 10px #0000000d}.event-datetime{text-transform:uppercase;letter-spacing:.06em;color:#6f8f72;margin:0;font-size:13px;font-weight:700}.event-title{color:#1f3556;margin:6px 0 0;font-size:17px;font-weight:700}.event-location{color:#6b7280;margin:6px 0 0;font-size:15px}.event-description{color:#374151;margin:12px 0 0;line-height:1.6}@media (max-width:900px){.family-grid{grid-template-columns:repeat(2,1fr)}.hero-grid{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}.admin-sections{grid-template-columns:1fr}}@media (max-width:640px){.page{padding:20px 14px}.site-header-inner{padding:12px 14px}.site-nav{width:100%}.family-grid{grid-template-columns:1fr}.title,.hero-title{font-size:30px}.stat-grid,.form-row{grid-template-columns:1fr}.modal{padding:22px 18px}}.auth-card{max-width:420px;margin-left:auto;margin-right:auto}.auth-form{gap:10px;margin-top:18px;display:grid}.form-label{color:#374151;margin-top:8px;font-weight:700}.auth-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:14px;margin:4px 0 0;padding:12px 14px}.auth-actions{flex-wrap:wrap;gap:12px;margin-top:24px;display:flex}.button-link{text-align:center;background:var(--color-primary,#047857);color:#fff;border-radius:12px;padding:10px 16px;font-size:14px;font-weight:700;text-decoration:none;display:inline-block}.secondary-button{background:#374151}.text-button{color:var(--color-primary,#047857);cursor:pointer;background:0 0;border:none;margin-top:12px;font-size:14px;font-weight:700}.admin-email-section{margin-bottom:28px}.form-input-readonly{color:#6b7280;cursor:default;background:#f9fafb}.status-disabled{color:#991b1b;background:#fee2e2}.admin-family-section{margin-bottom:28px}.admin-family-counts{margin:4px 0 12px}.admin-family-list{margin-top:12px}.admin-family-row{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:flex-start;gap:16px;padding:14px 0;display:flex}.admin-family-row:last-child{border-bottom:none}.admin-family-info{flex:1;min-width:0}.admin-family-name{color:#111827;margin:0 0 3px;font-size:16px;font-weight:700}.admin-family-meta{color:#6b7280;margin:2px 0 0;font-size:13px;line-height:1.5}.admin-family-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.status-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.status-active{color:#065f46;background:#d1fae5}.status-hidden{color:#6b7280;background:#f3f4f6}.admin-success{color:#065f46;background:#ecfdf5;border:1px solid #6ee7b7;border-radius:14px;margin:12px 0 4px;padding:12px 14px;font-size:14px;font-weight:600}.form-actions{flex-wrap:wrap;gap:12px;margin-top:8px;display:flex}.admin-announcement-section,.admin-calendar-section,.admin-google-calendar-section{margin-bottom:28px}.form-help-text{color:#6b7280;margin:4px 0 0;font-size:13px;line-height:1.5}.event-meta-row{margin-bottom:6px}.event-source-label{text-transform:uppercase;letter-spacing:.06em;border-radius:999px;padding:2px 9px;font-size:11px;font-weight:700;display:inline-block}.event-source-church{color:#1e40af;background:#dbeafe}.event-source-google{color:#9d174d;background:#fce7f3}.status-published{color:#065f46;background:#d1fae5}.status-draft{color:#92400e;background:#fef3c7}.profile-not-linked{text-align:center;max-width:560px;margin:0 auto;padding:32px 24px}.profile-pending-section{margin-top:4px}.profile-pending-list{margin-top:12px}.profile-pending-item{color:#374151;border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;gap:12px;padding:10px 0;font-size:14px;display:flex}.profile-pending-item:last-child{border-bottom:none}.admin-pending-section{margin-bottom:28px}.pending-change-list{margin-top:8px}.pending-change-card{border:1px solid #e5e7eb;border-radius:16px;margin-top:14px;padding:18px 20px}.pending-change-header{margin-bottom:10px}.pending-change-submitter{color:#111827;margin:0 0 3px;font-size:15px;font-weight:700}.pending-change-meta{color:#6b7280;margin:0;font-size:13px}.change-comparison{border:1px solid #e5e7eb;border-radius:10px;margin:14px 0;overflow:hidden}.change-comparison-header{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;background:#f9fafb;grid-template-columns:150px 1fr 1fr;gap:0 8px;padding:6px 12px;font-size:12px;font-weight:700;display:grid}.change-field-row{border-top:1px solid #f3f4f6;grid-template-columns:150px 1fr 1fr;align-items:start;gap:0 8px;padding:9px 12px;font-size:14px;display:grid}.change-field-label{color:#374151;font-weight:600}.change-old-value{color:#991b1b;word-break:break-word;background:#fef2f2;border-radius:6px;padding:2px 8px;line-height:1.5}.change-new-value{color:#065f46;word-break:break-word;background:#ecfdf5;border-radius:6px;padding:2px 8px;line-height:1.5}.pending-change-note{gap:6px;margin-bottom:12px;display:grid}.pending-change-actions{flex-wrap:wrap;gap:10px;display:flex}.btn-approve{color:#fff;background:#059669;border:none}.btn-approve:hover{background:#047857}.btn-danger{color:#fff;background:#dc2626;border:none}.btn-danger:hover{background:#b91c1c}@media (max-width:640px){.change-comparison-header{display:none}.change-field-row{grid-template-columns:1fr;gap:4px}.change-field-label{text-transform:uppercase;letter-spacing:.04em;color:#6b7280;font-size:12px}.admin-family-row{flex-direction:column;gap:10px}.admin-family-actions{width:100%}.admin-family-actions .btn{text-align:center;flex:1}}.family-avatar{border:1px solid #0000000f;border-radius:24px;width:78px;height:78px;margin-top:-62px;margin-bottom:16px;overflow:hidden;box-shadow:0 5px 18px #00000014}.family-avatar img{object-fit:cover;width:100%;height:100%;display:block}.family-detail-photo{border-radius:16px;width:100%;height:200px;margin-bottom:16px;overflow:hidden}.family-detail-photo img{object-fit:cover;width:100%;height:100%;display:block}.photo-preview-img{object-fit:cover;border-radius:12px;width:100%;max-height:180px;margin-top:10px;display:block}.form-input-file{color:#374151;cursor:pointer;width:100%;margin-top:10px;font-size:14px;display:block}.lightbox-overlay{z-index:300;background:#000000d9;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.lightbox-content{flex-direction:column;align-items:center;max-width:90vw;display:flex;position:relative}.lightbox-close{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:12px;align-self:flex-end;margin-bottom:10px;padding:8px 16px;font-size:13px;font-weight:700}.lightbox-close:hover{background:#ffffff47}.lightbox-img{object-fit:contain;border-radius:12px;max-width:90vw;max-height:80vh;display:block}.lightbox-caption{color:#fff;text-align:center;margin:12px 0 0;font-size:16px;font-weight:600}.admin-csv-section{margin-bottom:28px}.csv-section-desc{margin:0 0 20px}.csv-preview-stats{flex-wrap:wrap;gap:8px;margin:16px 0;display:flex}.csv-stat{color:#374151;background:#f3f4f6;border-radius:999px;padding:4px 12px;font-size:13px;font-weight:600;display:inline-block}.csv-stat-valid{color:#065f46;background:#d1fae5}.csv-stat-invalid{color:#991b1b;background:#fee2e2}.csv-preview-table-wrap{border:1px solid #e5e7eb;border-radius:14px;margin:0 0 20px;overflow-x:auto}.csv-preview-table{border-collapse:collapse;width:100%;min-width:700px;font-size:13px}.csv-preview-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:10px 12px;font-size:11px;font-weight:700}.csv-preview-table td{vertical-align:top;color:#1f2937;border-bottom:1px solid #f3f4f6;padding:9px 12px}.csv-preview-table tbody tr:last-child td{border-bottom:none}.csv-preview-table tbody tr:hover td{background:#f9fafb}.csv-row-invalid td{color:#9ca3af}.csv-cell-mono{font-family:monospace;font-size:12px}.csv-cell-note{color:#ef4444;min-width:160px;font-size:12px}.csv-preview-overflow{border-top:1px solid #f3f4f6;margin:0;padding:10px 14px;font-size:13px}.csv-options{background:#f9fafb;border:1px solid #e5e7eb;border-radius:14px;flex-direction:column;gap:10px;margin:0 0 20px;padding:16px;display:flex}.csv-options .form-label{margin:0 0 4px;font-size:13px}.csv-option-label{color:#374151;cursor:pointer;align-items:flex-start;gap:10px;font-size:14px;line-height:1.5;display:flex}.csv-option-label input[type=checkbox]{cursor:pointer;accent-color:#047857;flex-shrink:0;width:16px;height:16px;margin-top:2px}.csv-import-actions{flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:20px;display:flex}.csv-import-progress{margin:0;font-size:13px}.csv-import-summary{background:#f9fafb;border:1px solid #e5e7eb;border-radius:14px;margin-top:4px;padding:16px}.csv-import-summary .admin-success{margin:0 0 10px}.csv-summary-list{color:#374151;margin:0;padding-left:20px;font-size:14px;line-height:2}.csv-error-list{color:#ef4444;margin:4px 0 0;padding-left:20px;font-size:13px;line-height:1.8}.avatar-photo-btn{cursor:pointer;background:0 0;border:none;padding:0;display:block}.detail-photo-btn{cursor:pointer;background:0 0;border:none;width:100%;padding:0;display:block}.staff-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px;margin-bottom:20px;display:grid}.staff-card{text-align:left;flex-direction:row;align-items:flex-start;gap:14px;display:flex}.staff-contact-photo-wrap{flex-shrink:0}.staff-contact-photo{object-fit:cover;border-radius:8px;width:150px;height:150px;display:block;box-shadow:0 2px 8px #0000001a}.staff-contact-photo-placeholder{background:var(--color-accent,#d1fae5);width:150px;height:150px;color:var(--color-primary,#047857);border-radius:8px;justify-content:center;align-items:center;font-size:48px;font-weight:700;display:flex}.staff-contact-body{flex:1;min-width:0}.staff-name{color:#111827;margin:0 0 2px;font-size:15px;font-weight:700}.staff-role{color:var(--color-primary,#047857);text-transform:uppercase;letter-spacing:.07em;margin:0 0 6px;font-size:11px;font-weight:700}.staff-contact{color:#374151;margin:4px 0;font-size:14px}.staff-email-link{color:#047857;word-break:break-all;text-decoration:underline}.staff-bio{color:#6b7280;text-align:left;margin-top:12px;font-size:14px;line-height:1.6}.pastor-letter-card{margin-bottom:28px}.pastor-letter-title{color:#1f3556;margin:8px 0 16px;font-size:24px;font-weight:700}.pastor-letter-body{color:#374151;white-space:pre-wrap;margin-bottom:16px;font-size:15px;line-height:1.8}.pastor-letter-meta{color:#6b7280;margin:0;font-size:14px;font-weight:600}.resources-category-section{margin-bottom:32px}.resources-category-heading{color:#1f3556;border-bottom:2px solid #d1fae5;margin:0 0 10px;padding-bottom:8px;font-size:16px;font-weight:700}.resources-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;display:grid}.resource-card{flex-direction:column;display:flex}.resource-title{color:#111827;margin:0 0 6px;font-size:14px;font-weight:700}.resource-description{color:#6b7280;flex:1;margin:0 0 16px;font-size:14px;line-height:1.5}.resource-actions{flex-wrap:wrap;gap:8px;margin-top:auto;display:flex}@media (max-width:640px){.staff-grid,.resources-grid{grid-template-columns:1fr}}.app-shell{flex-direction:column;min-height:100dvh;display:flex}.app-header{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffeb;border-bottom:1px solid #00000014;position:sticky;top:0}.app-header-inner{justify-content:space-between;align-items:center;gap:12px;max-width:1100px;height:56px;margin:0 auto;padding:0 20px;display:flex}.app-logo{white-space:nowrap;flex-shrink:0;align-items:center;gap:8px;text-decoration:none;display:flex}.app-brand-logo{object-fit:contain;border-radius:4px;flex-shrink:0;width:auto;height:26px}.app-brand-name{color:#1f3556;font-size:17px;font-weight:700}.desktop-nav{flex-wrap:nowrap;align-items:center;gap:2px;display:flex}.desktop-nav-link{color:#374151;white-space:nowrap;border-radius:999px;padding:7px 12px;font-size:14px;text-decoration:none;transition:background .15s}.desktop-nav-link:hover{background:#f7f3eb}.desktop-nav-link-active{background:var(--color-accent,#d1fae5);color:var(--color-primary,#047857);font-weight:600}.desktop-nav-link-active:hover{background:var(--color-accent,#a7f3d0);filter:brightness(.96)}.mobile-menu-button{cursor:pointer;background:0 0;border:none;border-radius:8px;flex-direction:column;flex-shrink:0;justify-content:center;gap:5px;padding:8px;transition:background .12s;display:none}.mobile-menu-button:hover{background:#0000000d}.hamburger-line{background:#374151;border-radius:2px;width:22px;height:2px;display:block}.mobile-menu-panel{background:#fff;border-top:1px solid #0000000f;flex-direction:column;padding:6px 8px 10px;display:flex}.mobile-menu-link{color:#374151;border-radius:10px;padding:11px 14px;font-size:15px;font-weight:600;text-decoration:none;transition:background .12s;display:block}.mobile-menu-link:hover{background:var(--color-background,#f7f3eb)}.mobile-menu-link-active{background:var(--color-accent,#d1fae5);color:var(--color-primary,#047857)}.admin-dashboard-card{background:linear-gradient(135deg,#ecfdf5,#f0fdf4);border-color:#a7f3d0;margin-bottom:24px}.admin-dashboard-card-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}@media (max-width:759px){.desktop-nav{display:none}.mobile-menu-button{display:flex}.title{font-size:26px}.header-card{padding:20px 16px}.form-row,.family-grid{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}.admin-sections{grid-template-columns:1fr}.app-header{-webkit-backdrop-filter:none;backdrop-filter:none;background:#fffffffa}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:24px 24px 0 0;max-width:100%;max-height:calc(100dvh - 64px);margin:0;padding:24px 20px}.card-heading{font-size:18px}.admin-family-row{flex-direction:column;align-items:flex-start;gap:10px}.hero-grid{grid-template-columns:1fr}}@media (min-width:760px) and (max-width:960px){.desktop-nav-link{padding:6px 8px;font-size:12px}.app-brand-name{font-size:15px}}.member-list{gap:12px;display:grid}.member-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:14px;gap:14px;padding:16px;display:grid}.member-section-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.member-section-label{color:#1f3556;margin:0;font-size:14px;font-weight:700}.member-add-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.profile-form-section-heading{color:#374151;margin:0;font-size:15px;font-weight:700}.member-detail-list{gap:10px;margin-top:6px;display:grid}.member-detail-card{background:#f9fafb;border:1px solid #f3f4f6;border-radius:10px;padding:10px 14px}.member-detail-name{color:#111827;margin:0 0 4px;font-size:15px;font-weight:700}.member-detail-row{color:#374151;margin:3px 0;font-size:14px}.profile-header-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.family-card-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;display:grid}.family-card{cursor:pointer;text-align:left;background:#fff;border:none;border-radius:24px;flex-direction:column;width:100%;padding:0;transition:box-shadow .18s,transform .18s;display:flex;overflow:hidden;box-shadow:0 2px 12px #00000014}.family-card:hover{transform:translateY(-2px);box-shadow:0 6px 24px #00000024}.family-card:focus-visible{outline:2px solid var(--color-primary,#1f3556);outline-offset:2px}.family-card-photo-wrap{flex-shrink:0;width:100%;height:170px;overflow:hidden}.family-card-photo{object-fit:cover;width:100%;height:100%;display:block}.family-card-placeholder{background:linear-gradient(135deg, var(--color-primary,#1f3556) 0%, #2d5a8e 100%);color:#fff;letter-spacing:1px;justify-content:center;align-items:center;width:100%;height:100%;font-size:36px;font-weight:700;display:flex}.family-card-body{flex:1;min-width:0;padding:14px 16px 10px}.family-card-title{color:#111827;white-space:nowrap;text-overflow:ellipsis;margin:0 0 4px;font-size:16px;font-weight:700;overflow:hidden}.family-card-adults{color:#374151;white-space:nowrap;text-overflow:ellipsis;margin:0 0 2px;font-size:13px;overflow:hidden}.family-card-children{color:#6b7280;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:12px;overflow:hidden}.family-card-footer{padding:8px 16px 14px}.family-card-action{background:var(--color-primary,#1f3556);color:#fff;letter-spacing:.2px;border-radius:20px;padding:5px 14px;font-size:12px;font-weight:600;display:inline-block}.family-card:hover .family-card-action{background:var(--color-primary-dark,#162843)}@media (max-width:759px){.family-card-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.family-card-photo-wrap{height:150px}}@media (max-width:599px){.family-card-grid{grid-template-columns:1fr;gap:12px}.family-card{border-radius:16px;flex-direction:row}.family-card-photo-wrap{border-radius:0;flex-shrink:0;width:90px;height:auto;min-height:90px}.family-card-placeholder{min-height:90px;font-size:24px}.family-card-body{padding:12px 12px 6px}.family-card-footer{padding:0 12px 12px}}.admin-reset-section{background:#fff8f8!important;border:1px solid #fca5a5!important}.card-heading-danger,.reset-modal-title{color:#b91c1c}.reset-warning-box{background:#fef2f2;border:1px solid #fca5a5;border-radius:10px;padding:14px 16px}.reset-warning-text{color:#7f1d1d;margin:0;font-size:14px;line-height:1.6}.reset-progress{margin-top:14px;font-style:italic}.reset-summary{padding-top:4px}.reset-summary-list{gap:6px;margin:12px 0 0;padding:0;list-style:none;display:grid}.reset-summary-list li{color:#374151;font-size:14px}.adult-detail-card{background:#f9fafb;border:1px solid #eaecf0;border-radius:12px;gap:9px;padding:14px 14px 12px;display:grid}.child-detail-card{background:#f9fafb;border:1px solid #eaecf0;border-radius:10px;gap:5px;padding:10px 14px;display:grid}.adult-contact-row{justify-content:space-between;align-items:center;gap:10px;display:flex}.adult-contact-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.adult-contact-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.07em;font-size:10px;font-weight:700}.adult-contact-value{color:#1f2937;font-size:14px;line-height:1.3}.adult-contact-email{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.adult-contact-action{flex-shrink:0}.contact-action-button{color:#fff;white-space:nowrap;cursor:pointer;background:#1f3556;border:none;border-radius:999px;padding:4px 13px;font-size:12px;font-weight:700;text-decoration:none;transition:background .15s;display:inline-block}.adult-add-contact-row{border-top:1px solid #e9ebee;padding-top:4px}.add-contact-button{color:#374151;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #d1d5db;border-radius:999px;padding:5px 13px;font-size:12px;font-weight:600;transition:background .12s,border-color .12s;display:inline-block}.add-contact-button:hover{background:#f3f4f6;border-color:#9ca3af}.admin-section-title-row{align-items:baseline;gap:7px;display:flex}.admin-record-count{color:#9ca3af;font-size:14px;font-weight:600}.admin-compact-list{gap:5px;margin-top:10px;display:grid}.admin-compact-card{background:#f9fafb;border:1px solid #f3f4f6;border-radius:10px;align-items:center;gap:10px;padding:8px 10px;display:flex}.admin-compact-avatar{color:#fff;letter-spacing:.03em;background:linear-gradient(135deg,#1f3556,#2d5a8e);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:flex;overflow:hidden}.admin-compact-avatar img{object-fit:cover;width:100%;height:100%}.admin-compact-avatar-email{background:linear-gradient(135deg,#374151,#6b7280)}.admin-compact-main{flex:1;min-width:0}.admin-compact-title{color:#111827;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:14px;font-weight:700;overflow:hidden}.admin-compact-meta{color:#6b7280;flex-wrap:wrap;align-items:center;gap:5px;margin:3px 0 0;font-size:12px;display:flex}.admin-compact-linked{color:#9ca3af;text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-size:11px;overflow:hidden}.admin-compact-actions{flex-shrink:0;gap:5px;display:flex}.admin-show-toggle{color:#6b7280;cursor:pointer;background:0 0;border:1px dashed #d1d5db;border-radius:8px;width:100%;margin-top:8px;padding:8px 16px;font-size:13px;font-weight:600;transition:border-color .15s,color .15s;display:block}.admin-show-toggle:hover{color:#047857;border-color:#047857}.admin-badge{color:#374151;white-space:nowrap;background:#e5e7eb;border-radius:999px;padding:1px 7px;font-size:11px;font-weight:700;display:inline-block}.admin-badge-admin{background:var(--color-accent,#d1fae5);color:var(--color-primary-dark,#065f46)}.admin-badge-hidden{color:#713f12;background:#fef9c3}.admin-badge-disabled{color:#991b1b;background:#fee2e2}@media (max-width:480px){.admin-compact-card{flex-wrap:wrap}.admin-compact-actions{width:100%}}.cal-filters{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.cal-filter-chip{color:#6b7280;cursor:pointer;background:#fff;border:1.5px solid #d1d5db;border-radius:999px;align-items:center;gap:5px;padding:5px 12px;font-size:12px;font-weight:700;transition:border-color .15s,background .15s,color .15s;display:inline-flex}.cal-filter-chip-active{color:#fff;background:#1f3556;border-color:#1f3556}.cal-section{background:#fff;border:1px solid #0000000f;border-radius:16px;margin-bottom:18px;padding:14px;box-shadow:0 2px 10px #0000000d}.cal-nav{justify-content:space-between;align-items:center;gap:8px;margin-bottom:12px;display:flex}.cal-nav-arrows{gap:4px;display:flex}.cal-month-label{color:#1f3556;text-align:center;flex:1;font-size:15px;font-weight:700}.cal-nav-btn{cursor:pointer;color:#374151;background:#fff;border:1px solid #e5e7eb;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;font-size:18px;font-weight:700;line-height:1;transition:background .12s;display:flex}.cal-nav-btn:hover{background:#f3f4f6}.cal-today-btn{flex-shrink:0;padding:4px 10px!important;font-size:11px!important}.cal-today-spacer{flex-shrink:0;width:52px}.cal-grid{background:#f3f4f6;border:1px solid #f3f4f6;border-radius:10px;grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.cal-day-header{text-align:center;text-transform:uppercase;letter-spacing:.04em;color:#9ca3af;background:#f9fafb;padding:5px 2px;font-size:10px;font-weight:700}.cal-cell{background:#fff;min-height:64px;padding:3px 2px 2px;overflow:hidden}.cal-cell-empty{background:#fafafa;min-height:64px}.cal-cell-today{background:#f0fdf4}.cal-day-num{justify-content:center;align-items:center;height:20px;margin-bottom:2px;display:flex}.cal-day-num span{color:#374151;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:600;line-height:1;display:flex}.cal-today-badge{color:#fff!important;background:#047857!important}.cal-event-bar{color:#fff;cursor:pointer;text-align:left;text-overflow:ellipsis;white-space:nowrap;background:#1f3556;border:none;border-radius:3px;width:100%;margin-bottom:1px;padding:2px 3px;font-size:9px;font-weight:600;line-height:1.4;transition:opacity .12s;display:block;overflow:hidden}.cal-event-bar:hover{opacity:.82}.cal-more-btn{cursor:pointer;color:#9ca3af;text-align:left;background:0 0;border:none;width:100%;margin:0;padding:1px 3px;font-size:9px;font-weight:600;line-height:1.4;transition:color .12s;display:block}.cal-more-btn:hover{color:#374151}.event-card-clickable{cursor:pointer;transition:box-shadow .15s,transform .1s}.event-card-clickable:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0000001a}.event-card-clickable:focus-visible{outline-offset:2px;outline:2px solid #047857}.event-cal-badge{color:#374151;background:#e5e7eb;border:1px solid #0000;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.event-detail-row{color:#1f2937;align-items:baseline;gap:12px;margin-bottom:10px;font-size:14px;display:flex}.event-detail-label{text-transform:uppercase;letter-spacing:.06em;color:#9ca3af;flex-shrink:0;min-width:58px;margin:0;font-size:11px;font-weight:700}.event-detail-section{margin-bottom:12px}.event-detail-description{color:#374151;white-space:pre-wrap;margin:6px 0 0;font-size:14px;line-height:1.6}.event-detail-actions{border-top:1px solid #f3f4f6;gap:10px;margin-top:18px;padding-top:14px;display:flex}.admin-layout{background:#f7f3eb;min-height:calc(100dvh - 56px);display:flex}.admin-sidebar{background:#fff;border-right:1px solid #00000012;flex-direction:column;flex-shrink:0;gap:0;width:200px;height:calc(100dvh - 56px);padding:14px 8px 24px;display:flex;position:sticky;top:56px;overflow-y:auto}.admin-sidebar-group{margin-bottom:14px}.admin-sidebar-group:last-child{margin-bottom:0}.admin-sidebar-group-label{color:#9ca3af;letter-spacing:.1em;text-transform:uppercase;margin:0 0 2px;padding:0 10px;font-size:10px;font-weight:700}.admin-sidebar-heading{color:#9ca3af;letter-spacing:.09em;text-transform:uppercase;margin:0 0 8px;padding:0 8px;font-size:11px;font-weight:700}.admin-sidebar-button{text-align:left;color:#374151;cursor:pointer;background:0 0;border:none;border-radius:8px;width:100%;padding:9px 10px;font-size:13px;font-weight:600;transition:background .12s,color .12s;display:block}.admin-sidebar-button:hover{color:#1f3556;background:#f7f3eb}.admin-sidebar-button-active{background:var(--color-accent,#d1fae5);color:var(--color-primary,#047857)}.admin-sidebar-button-active:hover{background:var(--color-accent,#a7f3d0);filter:brightness(.96)}.admin-sidebar-button-danger{color:#b91c1c}.admin-sidebar-button-danger:hover{color:#991b1b;background:#fef2f2}.admin-dash-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.admin-dash-stat{cursor:pointer;text-align:center;background:#f9fafb;border:1px solid #eaecf0;border-radius:12px;flex-direction:column;align-items:center;gap:4px;padding:14px 6px;transition:background .12s,border-color .12s;display:flex}.admin-dash-stat:hover{background:var(--color-accent,#d1fae5);border-color:var(--color-primary,#047857)}.admin-dash-stat-alert{background:#fffbeb;border-color:#f59e0b}.admin-dash-stat-alert:hover{background:#fef3c7;border-color:#d97706}.admin-dash-stat-value{color:#111827;font-size:26px;font-weight:700;line-height:1}.admin-dash-stat-label{color:#6b7280;text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:600}@media (max-width:480px){.admin-dash-grid{grid-template-columns:repeat(2,1fr)}}.admin-content{flex:1;min-width:0;max-width:900px;padding:20px 24px}.admin-mobile-section-picker{padding:12px 16px 0;display:none}.admin-mobile-select{color:#1f3556;cursor:pointer;appearance:auto;background:#fff;border:1px solid #d1d5db;border-radius:10px;width:100%;padding:9px 12px;font-size:14px;font-weight:600}@media (max-width:759px){.admin-layout{flex-direction:column;min-height:auto}.admin-sidebar{display:none}.admin-mobile-section-picker{display:block}.admin-content{max-width:100%;padding:12px 14px}}.site-settings-logo-preview{object-fit:contain;background:#fff;border:1px solid #e5e7eb;border-radius:8px;max-width:200px;max-height:80px;padding:6px;display:block}.family-delete-modal{max-width:400px}.family-delete-name{color:#1f3556;font-weight:700}.danger-zone{border-top:1px solid #fee2e2;margin-top:24px;padding-top:18px}.danger-button{color:#fff;cursor:pointer;background:#dc2626;border:none}.danger-button:hover:not(:disabled){background:#b91c1c}.danger-button:disabled{opacity:.5;cursor:not-allowed}.delete-confirmation-box{background:#fff8f8;border:1px solid #fca5a5;border-radius:10px;padding:14px 16px}.delete-confirmation-box p{margin:0 0 8px}.delete-confirmation-input{border-color:#fca5a5!important}.delete-confirmation-input:focus{border-color:#dc2626!important;box-shadow:0 0 0 3px #fee2e2!important}.delete-confirmation-actions{flex-wrap:wrap;align-items:center;gap:10px;margin-top:12px;display:flex}.privacy-settings-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;margin-top:20px;padding:14px 16px}.privacy-settings-card h3{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px;font-size:12px;font-weight:700}.privacy-checkbox-grid{grid-template-columns:1fr 1fr;gap:4px 16px;display:grid}.privacy-checkbox-row{cursor:pointer;color:#374151;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;min-height:34px;padding:2px 0;font-size:13px;display:flex}.privacy-checkbox-row input[type=checkbox]{width:15px;height:15px;accent-color:var(--color-primary,#047857);cursor:pointer;flex-shrink:0}@media (max-width:480px){.privacy-checkbox-grid{grid-template-columns:1fr}}.compact-card{background:#fff;border:1px solid #0000000f;border-radius:12px;padding:12px 14px;box-shadow:0 2px 8px #0000000a}.compact-list{gap:8px;display:grid}.compact-button{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:6px 12px;font-size:13px;font-weight:600;transition:background .12s}.compact-button:hover{background:#f7f3eb}.compact-form{gap:10px;display:grid}.login-page{background:var(--color-background,#f7f3eb);justify-content:center;align-items:center;min-height:100dvh;padding:20px 16px;display:flex}.login-card{background:#fff;border:1px solid #00000012;border-radius:18px;width:100%;max-width:400px;padding:28px 24px;box-shadow:0 6px 24px #00000012}.login-heading{color:#111827;margin:6px 0 0;font-size:22px;font-weight:700;line-height:1.2}.login-subheading{color:#6b7280;margin:6px 0 0;font-size:13px;line-height:1.5}.login-form{gap:8px;margin-top:18px;display:grid}.login-input{box-sizing:border-box;background:#fff;border:1px solid #d1d5db;border-radius:10px;outline:none;width:100%;padding:9px 12px;font-size:14px}.login-input:focus{border-color:var(--color-primary,#047857);box-shadow:0 0 0 3px var(--color-accent,#d1fae5)}.login-submit-btn{width:100%;margin-top:6px;padding:10px;font-size:15px}.login-switch-btn{width:100%;color:var(--color-primary,#047857);cursor:pointer;text-align:center;background:0 0;border:none;margin-top:12px;font-size:13px;font-weight:600;display:block}.theme-presets-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-top:12px;display:grid}.theme-preset-card{cursor:pointer;text-align:left;background:#fff;border:2px solid #e5e7eb;border-radius:12px;flex-direction:column;align-items:flex-start;gap:8px;padding:12px;transition:border-color .15s,box-shadow .15s;display:flex}.theme-preset-card:hover{border-color:#9ca3af}.theme-preset-card-active{border-color:#047857;box-shadow:0 0 0 2px #d1fae5}.theme-swatch-row{gap:5px;display:flex}.theme-swatch{border-radius:50%;width:22px;height:22px;display:inline-block}.theme-swatch-bg{border:1px solid #e5e7eb}.theme-preset-name{color:#374151;margin:0;font-size:12px;font-weight:700}.theme-sample-btn{cursor:default;border-radius:8px;padding:4px 10px;font-size:11px;font-weight:700}@media (max-width:480px){.theme-presets-grid{grid-template-columns:repeat(2,1fr)}}.directory-top-strip{margin-bottom:16px}.latest-announcement-card{border:1px solid #0000000f;border-left:4px solid var(--color-primary,#047857);background:#fff;border-radius:10px;padding:12px 14px;box-shadow:0 2px 8px #0000000a}.latest-announcement-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary,#047857);margin:0 0 4px;font-size:10px;font-weight:700}.latest-announcement-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:4px;display:flex}.latest-announcement-title{color:#1f3556;flex:1;margin:0;font-size:15px;font-weight:700;line-height:1.3}.latest-announcement-preview{color:#6b7280;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 8px;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.latest-announcement-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:6px;display:flex}.latest-announcement-date{color:#9ca3af;font-size:12px}.latest-announcement-actions{color:var(--color-primary,#047857);white-space:nowrap;font-size:13px;font-weight:600;text-decoration:none}.latest-announcement-actions:hover{text-decoration:underline}.directory-section-tabs{background:#f3f4f6;border-radius:8px;gap:2px;margin-bottom:14px;padding:3px;display:inline-flex}.directory-section-tab{cursor:pointer;color:#6b7280;white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:5px 14px;font-size:13px;font-weight:600;transition:background .15s,color .15s}.directory-section-tab:hover{color:#374151;background:#0000000f}.directory-section-tab-active{background:var(--color-primary,#047857);color:#fff;box-shadow:0 1px 3px #00000024}.directory-section-tab-active:hover{background:var(--color-primary-dark,#065f46);color:#fff}.directory-controls-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.directory-search-input{background:#fff;border:1px solid #d1d5db;border-radius:10px;outline:none;flex:1;min-width:140px;max-width:320px;padding:8px 12px;font-size:14px}.directory-search-input:focus{border-color:var(--color-primary,#047857);box-shadow:0 0 0 3px var(--color-accent,#d1fae5)}.directory-sort-select{color:#374151;cursor:pointer;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E") right 10px center no-repeat;border:1px solid #d1d5db;border-radius:10px;outline:none;flex-shrink:0;width:158px;padding:8px 28px 8px 10px;font-size:13px;font-weight:500}.directory-sort-select:focus{border-color:var(--color-primary,#047857);box-shadow:0 0 0 3px var(--color-accent,#d1fae5)}.directory-count{color:#9ca3af;white-space:nowrap;flex-shrink:0;font-size:13px}@media (max-width:480px){.directory-search-input{max-width:100%}.directory-sort-select{width:100%}}.audit-log-controls{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.audit-log-search{background:#fff;border:1px solid #d1d5db;border-radius:8px;flex:1;min-width:180px;max-width:340px;padding:7px 10px;font-size:13px}.audit-log-search:focus{border-color:var(--color-primary,#047857);box-shadow:0 0 0 3px var(--color-accent,#d1fae5);outline:none}.audit-log-list{flex-direction:column;gap:6px;display:flex}.audit-log-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:10px 12px}.audit-log-top{flex-wrap:wrap;align-items:flex-start;gap:8px;display:flex}.audit-log-action-badge{color:#374151;white-space:nowrap;background:#f3f4f6;border-radius:4px;flex-shrink:0;padding:2px 7px;font-size:11px;font-weight:700;line-height:1.7}.audit-log-action-badge-danger{color:#991b1b;background:#fee2e2}.audit-log-summary{color:#374151;flex:1;min-width:0;font-size:13px;line-height:1.5}.audit-log-meta{color:#9ca3af;flex-wrap:wrap;gap:4px 10px;margin-top:4px;font-size:12px;display:flex}.audit-log-details-toggle{color:#6b7280;cursor:pointer;background:0 0;border:none;margin-top:6px;padding:0;font-size:12px;text-decoration:underline;display:inline-block}.audit-log-details-toggle:hover{color:#374151}.audit-log-details-block{white-space:pre-wrap;word-break:break-all;color:#374151;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;max-height:200px;margin-top:8px;padding:8px 10px;font-family:Courier New,Courier,monospace;font-size:12px;overflow-y:auto}.audit-log-note{color:#9ca3af;text-align:center;margin-top:14px;font-size:12px}.export-warning{color:#92400e;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;margin-bottom:18px;padding:8px 12px;font-size:13px}.export-button-list{flex-direction:column;gap:10px;display:flex}.export-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.export-btn{justify-content:flex-start;min-width:210px}.export-status{font-size:13px;line-height:1.4}.export-status-ok{color:#047857}.export-status-error{color:#dc2626}.profile-page{flex-direction:column;gap:14px;max-width:680px;display:flex}.profile-top-bar{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:10px;padding-bottom:4px;display:flex}.profile-title{color:#111827;margin:0 0 2px;font-size:22px;font-weight:700;line-height:1.2}.profile-muted-note{color:#6b7280;margin:0;font-size:13px;line-height:1.4}.profile-actions{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;display:flex}.profile-summary-card{padding:16px 20px}.profile-summary-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.profile-summary-name{color:#111827;margin:0;font-size:18px;font-weight:700}.profile-summary-body{flex-direction:column;gap:5px;margin-bottom:10px;display:flex}.profile-summary-row{color:#374151;gap:8px;font-size:14px;line-height:1.4;display:flex}.profile-summary-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;min-width:78px;padding-top:1px;font-size:12px;font-weight:600}.profile-section{border-top:1px solid #f3f4f6;margin-top:12px;padding-top:12px}.profile-section-label{letter-spacing:.06em;text-transform:uppercase;color:#9ca3af;margin:0 0 8px;font-size:11px;font-weight:700}.profile-members-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:8px;display:grid}.profile-family-member-card{background:#f9fafb;border:1px solid #f3f4f6;border-radius:10px;padding:10px 12px}.profile-member-name{color:#111827;margin:0 0 3px;font-size:14px;font-weight:600}.pending-change-notice{color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;padding:12px 16px;font-size:14px;line-height:1.5}.pending-change-badge{color:#92400e;white-space:nowrap;background:#fef3c7;border:1px solid #fde68a;border-radius:20px;flex-shrink:0;padding:3px 10px;font-size:12px;font-weight:700}.profile-form-section{border-bottom:1px solid #f3f4f6;gap:14px;padding-bottom:16px;display:grid}.profile-form-section:last-of-type{border-bottom:none;padding-bottom:0}.profile-form-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.profile-form-actions{flex-wrap:wrap;align-items:center;gap:10px;padding-top:4px;display:flex}@media (max-width:759px){.profile-page{max-width:100%}.profile-members-grid,.profile-form-grid{grid-template-columns:1fr}}.celebrations-page{flex-direction:column;gap:32px;display:flex}.celebrations-section{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e5e7eb);border-radius:10px;padding:20px 24px}.celebrations-section-title{letter-spacing:.04em;text-transform:uppercase;color:var(--color-primary,#047857);margin:0 0 14px;font-size:15px;font-weight:700}.celebration-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.celebration-item{background:var(--color-bg,#f7f3eb);border-radius:8px;align-items:center;gap:12px;padding:10px 12px;display:flex}.celebration-date-pill{background:var(--color-accent,#d1fae5);min-width:76px;color:var(--color-primary-dark,#065f46);text-align:center;border-radius:20px;flex-shrink:0;padding:3px 10px;font-size:13px;font-weight:600}.celebration-item-body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.celebration-name{color:var(--color-text,#1f2937);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.celebration-sub{color:var(--color-text-muted,#6b7280);font-size:12px}.celebration-years{color:var(--color-primary,#047857);font-size:12px;font-weight:600}.celebration-item-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.celebration-type-badge{letter-spacing:.06em;text-transform:uppercase;border-radius:12px;padding:2px 8px;font-size:11px;font-weight:700}.celebration-type-badge.birthday{color:#1d4ed8;background:#dbeafe}.celebration-type-badge.anniversary{color:#9d174d;background:#fce7f3}.celebration-days-label{color:var(--color-text-muted,#6b7280);white-space:nowrap;font-size:12px}.celebrations-preview-card{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e5e7eb);border-radius:10px;margin-bottom:12px;padding:14px 18px}.celebrations-preview-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.celebrations-preview-title{letter-spacing:.05em;text-transform:uppercase;color:var(--color-primary,#047857);font-size:13px;font-weight:700}.celebrations-preview-link{color:var(--color-primary,#047857);font-size:13px;font-weight:600;text-decoration:none}.celebrations-preview-link:hover{text-decoration:underline}.celebrations-preview-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.celebrations-preview-item{align-items:center;gap:10px;font-size:14px;display:flex}.celebrations-preview-date{min-width:68px;color:var(--color-primary-dark,#065f46);flex-shrink:0;font-size:12px;font-weight:600}.celebrations-preview-name{color:var(--color-text,#1f2937);white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.celebrations-preview-badge{letter-spacing:.05em;text-transform:uppercase;border-radius:10px;flex-shrink:0;padding:1px 7px;font-size:10px;font-weight:700}.celebrations-preview-badge.birthday{color:#1d4ed8;background:#dbeafe}.celebrations-preview-badge.anniversary{color:#9d174d;background:#fce7f3}.staff-section{margin-bottom:28px}.staff-section-title{color:var(--color-primary,#1f3556);text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid var(--color-primary,#1f3556);margin:0 0 12px;padding-bottom:6px;font-size:15px;font-weight:700}.staff-contact-card{align-items:flex-start;gap:14px;padding:14px 16px;display:flex}.staff-card-missing{opacity:.5}.contact-action-row{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.contact-action-button{color:#374151;cursor:pointer;white-space:nowrap;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600;line-height:1.4;text-decoration:none;transition:background .12s;display:inline-block}.contact-action-button:hover{color:#111827;background:#e5e7eb}.contact-action-copy{border-color:#d1d5db}.staff-source-picker{gap:20px;padding:10px 0 4px;display:flex}.staff-source-option{cursor:pointer;color:#374151;align-items:center;gap:6px;font-size:14px;display:flex}.staff-directory-member-select{position:relative}.staff-adult-dropdown{background:#fff;border:1px solid #d1d5db;border-radius:8px;max-height:220px;margin:4px 0 0;padding:0;list-style:none;overflow-y:auto;box-shadow:0 4px 12px #0000001a}.staff-adult-option{text-align:left;cursor:pointer;background:0 0;border:none;border-bottom:1px solid #f3f4f6;width:100%;padding:8px 12px;font-size:13px;display:block}.staff-adult-option:hover{background:#f9fafb}.staff-selected-member{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;font-size:14px;display:flex}.staff-selected-member-info{flex:1;min-width:0}.staff-source-badge{color:#1d4ed8;background:#dbeafe;border-radius:10px;margin-left:6px;padding:2px 8px;font-size:11px;font-weight:600}.admin-notes-card{background:#fffbeb;border:1px solid #fde68a;border-radius:10px;margin-bottom:12px;padding:12px 14px}.admin-notes-label{color:#92400e;margin:0 0 8px;font-size:13px;font-weight:700}.admin-notes-hint{color:#b45309;font-size:12px;font-weight:400}.resources-category-filter{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.resources-filter-btn{color:#374151;cursor:pointer;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:20px;padding:5px 14px;font-size:13px;font-weight:500;transition:background .12s}.resources-filter-btn:hover{background:#e5e7eb}.resources-filter-btn-active{background:var(--color-primary,#1f3556);border-color:var(--color-primary,#1f3556);color:#fff}.resource-pinned-section{margin-bottom:24px}.resource-card-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px;display:flex}.resource-pin-badge{color:#92400e;letter-spacing:.03em;white-space:nowrap;background:#fef3c7;border-radius:10px;flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:700}.data-health-list{border:1px solid #e5e7eb;border-radius:10px;flex-direction:column;gap:0;display:flex;overflow:hidden}.data-health-check-row{border-bottom:1px solid #e5e7eb}.data-health-check-row:last-child{border-bottom:none}.data-health-check-header{cursor:default;align-items:center;gap:10px;padding:10px 14px;display:flex}.data-health-has-issues .data-health-check-header{cursor:pointer}.data-health-has-issues .data-health-check-header:hover{background:#fef9ef}.data-health-ok .data-health-check-header{background:#f9fafb}.data-health-check-label{color:#374151;flex:1;font-size:14px}.data-health-count-badge{border-radius:12px;padding:2px 10px;font-size:13px;font-weight:700}.data-health-count-ok{color:#065f46;background:#d1fae5}.data-health-count-warn{color:#991b1b;background:#fee2e2}.data-health-expand-hint{color:#9ca3af;text-align:right;min-width:36px;font-size:12px}.data-health-detail-list{max-height:200px;margin:0;padding:0 14px 10px;list-style:none;overflow-y:auto}.data-health-detail-list li{color:#6b7280;border-bottom:1px solid #f3f4f6;padding:3px 0;font-size:13px}.data-health-detail-list li:last-child{border-bottom:none}.admin-badge-warn{color:#92400e;background:#fef3c7}.recent-activity-compact{margin-top:16px}.activity-list{flex-direction:column;gap:0;margin:0;padding:0;list-style:none;display:flex}.activity-item{border-bottom:1px solid #f3f4f6;grid-template-columns:130px 1fr auto;align-items:baseline;gap:8px;padding:8px 0;font-size:13px;display:grid}.activity-item:last-child{border-bottom:none}.activity-item-danger .activity-action-label{color:#991b1b}.activity-action-label{color:#374151;white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.activity-summary{color:#6b7280;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.activity-meta{flex-direction:column;align-items:flex-end;gap:2px;min-width:80px;display:flex}.activity-by{color:#9ca3af;text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-size:11px;overflow:hidden}.activity-time{color:#d1d5db;white-space:nowrap;font-size:11px}.sundown-calendar-note{color:#7c3aed;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;padding:1px 2px;font-size:10px;font-weight:600;line-height:1.3;overflow:hidden}.cal-cell-sabbath{background:#fdf8ff}@media (max-width:599px){.activity-item{grid-template-columns:1fr;gap:2px}.activity-meta{flex-direction:row;align-items:center;gap:6px}.staff-contact-photo,.staff-contact-photo-placeholder{width:96px;height:96px;font-size:32px}.contact-action-row{gap:4px}.contact-action-button{padding:3px 10px;font-size:11px}}.calendar-view-tabs{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e5e7eb);border-radius:8px;gap:4px;width:fit-content;margin-bottom:16px;padding:4px;display:flex}.calendar-view-tab{color:var(--color-text-muted,#6b7280);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:6px 16px;font-size:14px;font-weight:500;transition:background .12s,color .12s}.calendar-view-tab:hover{background:var(--color-bg,#f7f3eb);color:var(--color-text,#1f2937)}.calendar-view-tab-active{background:var(--color-primary,#047857);color:#fff}.calendar-view-tab-active:hover{background:var(--color-primary-dark,#065f46);color:#fff}.calendar-announcements-panel{margin-bottom:16px}.calendar-celebrations-link{justify-content:space-between;align-items:center;gap:12px;margin-top:16px;padding:14px 18px;display:flex}.calendar-celebrations-link-body{flex-direction:column;gap:2px;display:flex}.calendar-celebrations-link-title{color:var(--color-text,#1f2937);margin:0;font-size:15px;font-weight:600}.celebrations-view-tabs{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e5e7eb);border-radius:8px;gap:4px;width:fit-content;margin-bottom:20px;padding:4px;display:flex}.celebrations-view-tab{color:var(--color-text-muted,#6b7280);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:6px 16px;font-size:14px;font-weight:500;transition:background .12s,color .12s}.celebrations-view-tab:hover{background:var(--color-bg,#f7f3eb);color:var(--color-text,#1f2937)}.celebrations-view-tab-active{background:var(--color-primary,#047857);color:#fff}.celebrations-view-tab-active:hover{background:var(--color-primary-dark,#065f46);color:#fff}.celebrations-year-list{flex-direction:column;gap:24px;display:flex}.celebrations-month-section{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e5e7eb);border-radius:10px;padding:16px 20px}.celebrations-month-title{letter-spacing:.04em;text-transform:uppercase;color:var(--color-primary,#047857);border-bottom:1px solid var(--color-border,#e5e7eb);margin:0 0 12px;padding-bottom:6px;font-size:15px;font-weight:700}.celebrations-year-item{background:var(--color-bg,#f7f3eb);border-radius:7px;align-items:center;gap:10px;padding:8px 10px;display:flex}.celebrations-year-day{min-width:32px;color:var(--color-primary,#047857);text-align:center;flex-shrink:0;font-size:15px;font-weight:700}.celebrations-year-item-body{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.contact-icon-svg{width:18px;height:18px;display:block}.contact-icon-button{border:1px solid var(--color-border,#e5e7eb);background:var(--color-card,#fff);width:36px;height:36px;color:var(--color-primary,#1f3556);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;text-decoration:none;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.contact-icon-button:hover{background:var(--color-primary,#1f3556);color:#fff;border-color:var(--color-primary,#1f3556)}.contact-icon-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.admin-subtabs{border-bottom:1px solid var(--color-border,#e5e7eb);gap:4px;margin-bottom:20px;padding-bottom:0;display:flex}.admin-subtab{cursor:pointer;color:var(--color-muted,#6b7280);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 16px;font-size:14px;font-weight:500;transition:color .15s,border-color .15s}.admin-subtab:hover{color:var(--color-primary,#1f3556)}.admin-subtab-active{color:var(--color-primary,#1f3556);border-bottom-color:var(--color-primary,#1f3556);font-weight:600}.profile-photo-request{margin-top:16px}.profile-photo-request .card-heading{margin-bottom:12px;font-size:16px}.profile-photo-upload-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.profile-photo-preview{margin-top:12px}.profile-photo-preview img{object-fit:cover;border:1px solid var(--color-border,#e5e7eb);border-radius:8px;max-width:200px;max-height:200px;display:block}.profile-photo-actions{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.photo-change-compare{flex-wrap:wrap;gap:16px;margin:8px 0 12px;display:flex}.photo-change-side{flex:1;min-width:120px}.photo-change-label{color:var(--color-muted,#6b7280);margin-bottom:6px;font-size:12px;font-weight:600}.photo-change-img{aspect-ratio:1;object-fit:cover;border:1px solid var(--color-border,#e5e7eb);border-radius:8px;width:100%;max-width:160px;display:block}.photo-change-placeholder{aspect-ratio:1;border:1px solid var(--color-border,#e5e7eb);background:var(--color-bg,#f3f4f6);width:100%;max-width:160px;color:var(--color-muted,#9ca3af);border-radius:8px;justify-content:center;align-items:center;font-size:13px;display:flex}.family-doc-id-row{background:var(--color-bg,#f9fafb);border-radius:6px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;padding:8px 12px;display:flex}.family-doc-id-label{color:var(--color-muted,#6b7280);flex-shrink:0;font-size:12px;font-weight:600}.family-doc-id-value{color:var(--color-text,#111827);word-break:break-all;background:0 0;flex:auto;padding:0;font-family:ui-monospace,Cascadia Code,Source Code Pro,Menlo,Consolas,monospace;font-size:12px}.copy-id-button{border:1px solid var(--color-border,#d1d5db);background:var(--color-surface,#fff);color:var(--color-text,#374151);cursor:pointer;border-radius:4px;flex-shrink:0;padding:3px 10px;font-size:11px;transition:background .15s}.copy-id-button:hover{background:var(--color-bg,#f3f4f6)}.family-linker{position:relative}.family-linker-selected{background:var(--color-bg,#f9fafb);border:1px solid var(--color-border,#d1d5db);border-radius:6px;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 10px;display:flex}.family-linker-missing{background:#fff5f5;border-color:#fca5a5}.family-linker-name{color:var(--color-text,#111827);flex:auto;font-size:14px;font-weight:500}.family-linker-id{color:var(--color-muted,#6b7280);word-break:break-all;background:0 0;flex-shrink:0;padding:0;font-family:ui-monospace,Cascadia Code,Source Code Pro,Menlo,Consolas,monospace;font-size:11px}.family-linker-dropdown{background:var(--color-surface,#fff);border:1px solid var(--color-border,#d1d5db);z-index:200;border-radius:6px;max-height:240px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden auto;box-shadow:0 4px 12px #0000001a}.family-linker-option{border:none;border-bottom:1px solid var(--color-border,#f3f4f6);text-align:left;cursor:pointer;background:0 0;justify-content:space-between;align-items:center;gap:8px;width:100%;padding:8px 12px;display:flex}.family-linker-option:last-child{border-bottom:none}.family-linker-option:hover{background:var(--color-bg,#f9fafb)}.family-linker-option-name{color:var(--color-text,#111827);text-align:left;flex:auto;font-size:13px}.family-linker-option-id{color:var(--color-muted,#9ca3af);text-overflow:ellipsis;white-space:nowrap;background:0 0;flex-shrink:0;max-width:160px;font-family:ui-monospace,Cascadia Code,Source Code Pro,Menlo,Consolas,monospace;font-size:11px;overflow:hidden}.family-linker-empty{color:var(--color-muted,#9ca3af);margin:0;padding:10px 12px;font-size:13px}.linked-family-warning{color:#dc2626;margin-top:4px;margin-bottom:0;font-size:12px}.admin-badge-warning{color:#dc2626;background:#fef2f2;border:1px solid #fca5a5}.admin-compact-meta-dim{color:var(--color-muted,#d1d5db);font-size:11px;font-style:italic}.staff-role-pill{white-space:nowrap;vertical-align:middle;border-radius:99px;padding:3px 7px;font-size:11px;font-weight:600;line-height:1;display:inline-block}.staff-role-pill-pastor{color:#5b21b6;background:#ede9fe}.staff-role-pill-elder{color:#1e40af;background:#dbeafe}.staff-role-pill-deacon{color:#166534;background:#dcfce7}.staff-role-pill-deaconess{color:#9d174d;background:#fce7f3}.staff-role-pill-support{color:#92400e;background:#fef3c7}.staff-role-pill-other{color:#4b5563;background:#f3f4f6}.staff-role-pill-row{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.member-detail-name-row{flex-wrap:wrap;align-items:flex-start;gap:6px;margin-bottom:4px;display:flex}.family-card-adult-item{flex-wrap:wrap;align-items:center;gap:4px;margin-right:6px;display:inline-flex}.family-card-adults{flex-wrap:wrap;align-items:center;gap:4px 0;display:flex}
