@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=DM+Sans:wght@300;400;500&display=swap";:root{--primary:#4f46e5;--primary-light:#eef2ff;--primary-dark:#3730a3;--primary-hover:#4338ca;--accent:#10b981;--accent-light:#d1fae5;--accent-dark:#059669;--bg:#f8fafc;--surface:#fff;--surface-2:#f1f5f9;--border:#e2e8f0;--border-strong:#cbd5e1;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-inverse:#fff;--success:#10b981;--success-bg:#d1fae5;--success-text:#065f46;--warning:#f59e0b;--warning-bg:#fef3c7;--warning-text:#92400e;--danger:#ef4444;--danger-bg:#fee2e2;--danger-text:#991b1b;--info:#3b82f6;--info-bg:#dbeafe;--info-text:#1e40af;--font-heading:"Plus Jakarta Sans", sans-serif;--font-body:"DM Sans", sans-serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--weight-regular:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--weight-extrabold:800;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014, 0 2px 4px #0000000a;--shadow-lg:0 8px 24px #0000001a, 0 4px 8px #0000000a;--shadow-xl:0 20px 48px #0000001f;--sidebar-width:260px;--navbar-height:64px;--bottom-nav-height:64px;--container-max:1200px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--z-base:1;--z-dropdown:500;--z-sidebar:900;--z-overlay:1050;--z-navbar:1000;--z-modal:1100;--z-toast:1200;--focus-ring:0 0 0 3px #4f46e533}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);font-size:var(--text-base);color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}img,video{max-width:100%;display:block}input,button,textarea,select{font-family:inherit;font-size:inherit}button{cursor:pointer;background:0 0;border:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:var(--weight-bold);color:var(--text-primary);line-height:1.2}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}p{color:var(--text-secondary);line-height:1.7}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}:focus-visible{box-shadow:var(--focus-ring);outline:none}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.font-heading{font-family:var(--font-heading)}.font-medium{font-weight:var(--weight-medium)}.font-semibold{font-weight:var(--weight-semibold)}.font-bold{font-weight:var(--weight-bold)}.surface{background:var(--surface)}.rounded{border-radius:var(--radius-md)}.shadow{box-shadow:var(--shadow-md)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fadeIn{animation:fadeIn var(--transition-base) ease forwards}.animate-slideUp{animation:slideUp var(--transition-base) ease forwards}.animate-slideLeft{animation:slideInLeft var(--transition-base) ease forwards}[data-theme=dark]{--bg:#0f172a;--surface:#1e293b;--surface-2:#293548;--border:#334155;--border-strong:#475569;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-muted:#64748b;--text-inverse:#0f172a;--primary-light:#4f46e526;--accent-light:#10b98126;--success-bg:#10b9811f;--success-text:#6ee7b7;--warning-bg:#f59e0b1f;--warning-text:#fcd34d;--danger-bg:#ef44441f;--danger-text:#fca5a5;--info-bg:#3b82f61f;--info-text:#93c5fd;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--shadow-xl:0 20px 48px #0009}[data-theme=dark] .form-input,[data-theme=dark] .filter-select,[data-theme=dark] .search-input{background:var(--surface-2);color:var(--text-primary);border-color:var(--border)}[data-theme=dark] .form-input::placeholder,[data-theme=dark] .search-input::placeholder{color:var(--text-muted)}[data-theme=dark] .modal{background:var(--surface)}[data-theme=dark] .modal-header{background:var(--surface);border-bottom-color:var(--border)}[data-theme=dark] .login-form-panel{background:var(--bg)}[data-theme=dark] .login-error{background:var(--danger-bg);border-color:var(--danger-text)}[data-theme=dark] .calendar-cell-today{background:#4f46e526!important}*,:before,:after{transition:background-color .2s,border-color .2s,color .15s}.login-page{background:var(--surface);min-height:100vh;display:flex}.login-brand{background:linear-gradient(145deg, var(--primary-dark) 0%, var(--primary) 60%, #6366f1 100%);width:480px;padding:var(--space-12);flex-shrink:0;align-items:center;display:flex;position:relative;overflow:hidden}.login-brand-inner{z-index:2;position:relative}.login-logo{min-width:20px;min-height:20px;padding:var(--space-3);border-radius:var(--radius-lg);margin-bottom:var(--space-1);background:#ffffff26;border:1px solid #fff3;justify-content:center;align-items:center;display:inline-flex}.login-brand-title{font-family:var(--font-heading);font-size:var(--text-4xl);font-weight:var(--weight-extrabold);color:#fff;margin-bottom:var(--space-4);letter-spacing:-.5px}.login-brand-sub{font-size:var(--text-lg);color:#ffffffbf;margin-bottom:var(--space-10);max-width:320px;line-height:1.6}.login-features{gap:var(--space-4);flex-direction:column;display:flex}.login-feature-item{align-items:center;gap:var(--space-3);color:#ffffffe6;font-size:var(--text-sm);font-weight:var(--weight-medium);animation:slideInLeft var(--transition-base) ease both;display:flex}.login-feature-dot{border-radius:var(--radius-full);background:var(--accent);flex-shrink:0;width:8px;height:8px}.login-circle{border-radius:var(--radius-full);z-index:1;background:#ffffff0d;position:absolute}.login-circle-1{width:400px;height:400px;bottom:-150px;right:-100px}.login-circle-2{width:250px;height:250px;top:-80px;right:60px}.login-form-panel{padding:var(--space-8);background:var(--bg);flex:1;justify-content:center;align-items:center;display:flex}.login-form-inner{width:100%;max-width:420px}.login-form-header{margin-bottom:var(--space-8)}.login-form-header h2{font-family:var(--font-heading);font-size:var(--text-3xl);font-weight:var(--weight-extrabold);color:var(--text-primary);margin-bottom:var(--space-2);letter-spacing:-.5px}.login-form-header p{color:var(--text-secondary);font-size:var(--text-base)}.login-error{background:var(--danger-bg);color:var(--danger-text);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--weight-medium);margin-bottom:var(--space-6);border:1px solid #fecaca}.login-form{gap:var(--space-5);margin-bottom:var(--space-6);flex-direction:column;display:flex}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary)}.form-label-row{justify-content:space-between;align-items:center;display:flex}.form-link{font-size:var(--text-sm);color:var(--primary);font-weight:var(--weight-medium);transition:color var(--transition-fast)}.form-link:hover{color:var(--primary-dark)}.form-input{border:1.5px solid var(--border);border-radius:var(--radius-md);background:var(--surface);width:100%;color:var(--text-primary);font-size:var(--text-base);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:.75rem 1rem}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:var(--primary);box-shadow:var(--focus-ring)}.input-password-wrapper{position:relative}.input-password-wrapper .form-input{padding-right:3rem}.password-toggle{cursor:pointer;padding:var(--space-1);background:0 0;border:none;align-items:center;display:flex;position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.btn-login{background:var(--primary);color:#fff;border-radius:var(--radius-md);width:100%;font-family:var(--font-heading);font-size:var(--text-base);font-weight:var(--weight-semibold);justify-content:center;align-items:center;gap:var(--space-2);transition:background var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);margin-top:var(--space-2);padding:.875rem 1.5rem;display:flex;box-shadow:0 4px 14px #4f46e566}.btn-login:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 20px #4f46e573}.btn-login:active:not(:disabled){transform:translateY(0)}.btn-login:disabled{opacity:.7;cursor:not-allowed}.spin{animation:1s linear infinite spin}.login-register-link{text-align:center;font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-8)}.login-register-link a{color:var(--primary);font-weight:var(--weight-semibold)}.login-register-link a:hover{color:var(--primary-dark)}.login-footer{text-align:center;font-size:var(--text-xs);color:var(--text-muted)}@media (width<=768px){.login-page{flex-direction:column}.login-brand{width:100%;padding:var(--space-8) var(--space-6);align-items:flex-end;min-height:280px}.login-brand-sub{font-size:var(--text-base);margin-bottom:var(--space-6)}.login-features{display:none}.login-form-panel{padding:var(--space-6);align-items:flex-start}.login-form-inner{padding-top:var(--space-4)}.login-form-header h2{font-size:var(--text-2xl)}}.dashboard{gap:var(--space-6);flex-direction:column;display:flex}.dashboard-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.dashboard-greeting{font-size:var(--text-2xl);font-weight:var(--weight-extrabold);color:var(--text-primary);margin-bottom:var(--space-1)}.dashboard-sub{color:var(--text-secondary);font-size:var(--text-sm)}.stat-grid{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.stat-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-5);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast), transform var(--transition-fast)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-top{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.stat-card-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:40px;height:40px;display:flex}.stat-trend{font-size:var(--text-xs);font-weight:var(--weight-semibold);border-radius:var(--radius-full);padding:2px 8px}.stat-trend.up{background:var(--success-bg);color:var(--success-text)}.stat-trend.down{background:var(--warning-bg);color:var(--warning-text)}.stat-card-value{font-family:var(--font-heading);font-size:var(--text-3xl);font-weight:var(--weight-extrabold);color:var(--text-primary);margin-bottom:var(--space-1);line-height:1}.stat-card-label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary)}.stat-card-sublabel{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.dashboard-bottom{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.health-score-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-6);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.health-score-header{margin-bottom:var(--space-5)}.health-score-header h3{font-size:var(--text-base);font-weight:var(--weight-bold);color:var(--text-primary)}.health-score-header p{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.health-score-body{align-items:center;gap:var(--space-6);display:flex}.health-ring-wrap{flex-shrink:0;width:120px;height:120px;position:relative}.health-ring{width:120px;height:120px}.health-ring-label{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.health-ring-value{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--weight-extrabold);line-height:1}.health-ring-status{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.health-factors{gap:var(--space-3);flex-direction:column;flex:1;display:flex}.health-factor-item{align-items:center;gap:var(--space-3);display:flex}.health-factor-label{font-size:var(--text-xs);color:var(--text-secondary);flex-shrink:0;width:130px}.health-factor-bar-wrap{background:var(--surface-2);border-radius:var(--radius-full);flex:1;height:6px;overflow:hidden}.health-factor-bar{border-radius:var(--radius-full);height:100%;transition:width 1s}.health-factor-value{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-secondary);text-align:right;width:36px}.activity-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-6);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.activity-header{margin-bottom:var(--space-5);justify-content:space-between;align-items:center;display:flex}.activity-header h3{font-size:var(--text-base);font-weight:var(--weight-bold)}.activity-list{gap:var(--space-4);flex-direction:column;display:flex}.activity-item{align-items:flex-start;gap:var(--space-3);display:flex}.activity-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;margin-top:2px;display:flex}.activity-text{font-size:var(--text-sm);color:var(--text-primary);line-height:1.5}.activity-time{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.btn-primary{align-items:center;gap:var(--space-2);padding:.625rem var(--space-4);background:var(--primary);color:#fff;border-radius:var(--radius-md);font-family:var(--font-heading);font-size:var(--text-sm);font-weight:var(--weight-semibold);transition:all var(--transition-fast);white-space:nowrap;cursor:pointer;border:none;display:flex;box-shadow:0 2px 8px #4f46e54d}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #4f46e559}.btn-ghost{font-size:var(--text-sm);color:var(--primary);font-weight:var(--weight-medium);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:background var(--transition-fast);cursor:pointer;background:0 0;border:none}.btn-ghost:hover{background:var(--primary-light)}@media (width<=768px){.stat-grid{grid-template-columns:repeat(2,1fr)}.dashboard-bottom{grid-template-columns:1fr}.health-score-body{flex-direction:column;align-items:flex-start}.dashboard-header{flex-direction:column}.btn-primary{justify-content:center;width:100%}}@media (width<=480px){.stat-grid{grid-template-columns:1fr}}.login-register-cta{align-items:center;gap:var(--space-3);margin-bottom:var(--space-8);flex-direction:column;display:flex}.login-register-divider{font-size:var(--text-sm);color:var(--text-secondary);text-align:center;margin:0}.btn-register{justify-content:center;align-items:center;gap:var(--space-2);border:1.5px solid var(--primary);border-radius:var(--radius-md);width:100%;color:var(--primary);font-family:var(--font-heading);font-size:var(--text-base);font-weight:var(--weight-semibold);transition:background var(--transition-fast), color var(--transition-fast);background:0 0;padding:.75rem 1.5rem;text-decoration:none;display:flex}.btn-register:hover{background:var(--primary-light);color:var(--primary-dark)}.members-page{gap:var(--space-6);flex-direction:column;display:flex}.page-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.page-title{font-size:var(--text-2xl);font-weight:var(--weight-extrabold);color:var(--text-primary);margin-bottom:var(--space-1)}.page-subtitle{color:var(--text-secondary);font-size:var(--text-sm)}.filters-bar{gap:var(--space-3);background:var(--surface);padding:var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);flex-wrap:wrap;display:flex}.search-wrap{flex:1;min-width:200px;position:relative}.search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:.875rem;transform:translateY(-50%)}.search-input{border:1.5px solid var(--border);border-radius:var(--radius-md);width:100%;font-size:var(--text-sm);color:var(--text-primary);background:var(--bg);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:.625rem 1rem .625rem 2.5rem}.search-input:focus{border-color:var(--primary);box-shadow:var(--focus-ring)}.search-input::placeholder{color:var(--text-muted)}.filter-selects{gap:var(--space-3);display:flex}.filter-select{padding:.625rem var(--space-4);border:1.5px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary);background:var(--bg);cursor:pointer;transition:border-color var(--transition-fast);outline:none}.filter-select:focus{border-color:var(--primary)}.members-content{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}.table-wrap{overflow-x:auto}.members-table{border-collapse:collapse;width:100%}.members-table th{padding:var(--space-3) var(--space-5);text-align:left;font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;background:var(--surface-2);border-bottom:1px solid var(--border)}.member-row{cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border)}.member-row:last-child{border-bottom:none}.member-row:hover{background:var(--surface-2)}.member-row td{padding:var(--space-4) var(--space-5);font-size:var(--text-sm);color:var(--text-secondary);vertical-align:middle}.member-cell-identity{align-items:center;gap:var(--space-3);display:flex}.member-avatar{border-radius:var(--radius-full);background:var(--primary-light);width:38px;height:38px;color:var(--primary);font-family:var(--font-heading);font-weight:var(--weight-bold);font-size:var(--text-sm);flex-shrink:0;justify-content:center;align-items:center;display:flex}.member-name{font-weight:var(--weight-semibold);color:var(--text-primary);font-size:var(--text-sm)}.member-id{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.member-cell-phone,.member-cell-date{align-items:center;gap:var(--space-2);font-size:var(--text-sm);display:flex}.member-action-btn{border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.member-action-btn:hover{background:var(--surface-2);color:var(--text-primary)}.member-cards-list{flex-direction:column;gap:0;display:none}.audit-cards-list{display:none}.member-card{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.member-card:last-child{border-bottom:none}.member-card:hover{background:var(--surface-2)}.member-card-left{align-items:center;gap:var(--space-3);display:flex}.member-card-phone{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.badge{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--weight-semibold);white-space:nowrap;align-items:center;padding:3px 10px;display:inline-flex}.badge-success{background:var(--success-bg);color:var(--success-text)}.badge-warning{background:var(--warning-bg);color:var(--warning-text)}.badge-info{background:var(--info-bg);color:var(--info-text)}.badge-danger{background:var(--danger-bg);color:var(--danger-text)}.badge-neutral{background:var(--surface-2);color:var(--text-secondary)}.pagination{justify-content:center;align-items:center;gap:var(--space-4);padding:var(--space-4);border-top:1px solid var(--border);display:flex}.page-btn{border-radius:var(--radius-md);border:1.5px solid var(--border);width:34px;height:34px;color:var(--text-secondary);transition:all var(--transition-fast);background:var(--surface);justify-content:center;align-items:center;display:flex}.page-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-info{font-size:var(--text-sm);color:var(--text-secondary)}.empty-state{padding:var(--space-16) var(--space-8);justify-content:center;align-items:center;gap:var(--space-3);text-align:center;flex-direction:column;display:flex}.empty-state-icon{border-radius:var(--radius-xl);background:var(--surface-2);width:64px;height:64px;margin-bottom:var(--space-2);justify-content:center;align-items:center;display:flex}.empty-state-title{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--text-primary)}.empty-state-message{font-size:var(--text-sm);color:var(--text-muted);max-width:320px}.spinner-wrap{padding:var(--space-16);justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}.spinner-message{font-size:var(--text-sm);color:var(--text-muted)}.modal-overlay{z-index:var(--z-overlay);padding:var(--space-4);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-height:90vh;z-index:var(--z-modal);flex-direction:column;display:flex;overflow-y:auto}.modal-sm{max-width:400px}.modal-md{max-width:560px}.modal-lg{max-width:720px}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border);background:var(--surface);z-index:1;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.modal-title{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--text-primary)}.modal-close{border-radius:var(--radius-md);width:34px;height:34px;color:var(--text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--surface-2);color:var(--text-primary)}.modal-body{padding:var(--space-6);overflow-y:auto}.member-form{gap:var(--space-6);flex-direction:column;display:flex}.form-section{gap:var(--space-4);flex-direction:column;display:flex}.form-section-title{font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--text-primary);text-transform:uppercase;letter-spacing:.06em;padding-bottom:var(--space-2);border-bottom:1px solid var(--border)}.form-row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.form-error{background:var(--danger-bg);color:var(--danger-text);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--weight-medium);border:1px solid #fecaca}.form-group-checkbox{justify-content:flex-end}.checkbox-label{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;margin-top:var(--space-1);display:flex}.form-actions{justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--border);display:flex}.btn-outline{padding:.625rem var(--space-4);border:1.5px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-secondary);background:var(--surface);cursor:pointer;transition:all var(--transition-fast)}.btn-outline:hover{border-color:var(--border-strong);color:var(--text-primary)}.member-profile-preview{gap:var(--space-6);flex-direction:column;display:flex}.profile-preview-header{align-items:center;gap:var(--space-4);display:flex}.profile-preview-avatar{border-radius:var(--radius-full);background:var(--primary-light);width:64px;height:64px;color:var(--primary);font-family:var(--font-heading);font-weight:var(--weight-extrabold);font-size:var(--text-xl);flex-shrink:0;justify-content:center;align-items:center;display:flex}.profile-preview-name{font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--text-primary);margin-bottom:var(--space-1)}.profile-preview-id{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--space-2)}.profile-preview-details{border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:0;display:flex;overflow:hidden}.profile-detail-row{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);font-size:var(--text-sm);justify-content:space-between;align-items:center;display:flex}.profile-detail-row:last-child{border-bottom:none}.profile-detail-label{color:var(--text-muted);font-weight:var(--weight-medium)}.profile-detail-value{color:var(--text-primary);font-weight:var(--weight-medium);text-align:right}@media (width<=768px){.filters-bar,.filter-selects{flex-direction:column}.form-row{grid-template-columns:1fr}.page-header{flex-direction:column}.modal-body{padding:var(--space-4)}}.attendance-page{gap:var(--space-6);flex-direction:column;display:flex;position:relative}.success-toast{top:calc(var(--navbar-height) + var(--space-4));right:var(--space-6);background:var(--success);color:#fff;padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-semibold);align-items:center;gap:var(--space-2);box-shadow:var(--shadow-lg);z-index:var(--z-toast);display:flex;position:fixed}.attendance-stats-row{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.attendance-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);align-items:center;gap:var(--space-4);box-shadow:var(--shadow-sm);display:flex}.attendance-stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.attendance-stat-value{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--weight-extrabold);color:var(--text-primary);line-height:1}.attendance-stat-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.services-list-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.services-list-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border);background:var(--surface-2)}.services-list-header h3{font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.services-list{flex-direction:column;display:flex}.service-card{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:var(--space-4);transition:background var(--transition-fast);display:flex}.service-card:last-child{border-bottom:none}.service-card:hover{background:var(--surface-2)}.service-card-left{align-items:flex-start;gap:var(--space-4);flex:1;min-width:0;display:flex}.service-card-icon{border-radius:var(--radius-md);background:var(--primary-light);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.service-card-name-row{align-items:center;gap:var(--space-3);margin-bottom:var(--space-1);flex-wrap:wrap;display:flex}.service-card-name{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--text-primary)}.service-type-badge{font-size:var(--text-xs);font-weight:var(--weight-semibold);border-radius:var(--radius-full);padding:2px 8px}.service-card-meta{align-items:center;gap:var(--space-4);font-size:var(--text-xs);color:var(--text-muted);flex-wrap:wrap;display:flex}.service-card-meta span{align-items:center;gap:var(--space-1);display:flex}.service-present-count{font-weight:var(--weight-semibold);color:var(--success)!important}.service-attendance-bar-wrap{align-items:center;gap:var(--space-3);margin-top:var(--space-2);display:flex}.service-attendance-bar{border-radius:var(--radius-full);flex:1;min-width:60px;max-width:160px;height:4px;transition:width .8s}.service-attendance-rate{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap}.service-card-actions{flex-shrink:0}.take-attendance{gap:var(--space-4);flex-direction:column;display:flex}.attendance-service-info{justify-content:space-between;align-items:flex-start;gap:var(--space-4);padding:var(--space-4);background:var(--primary-light);border-radius:var(--radius-md);flex-wrap:wrap;display:flex}.attendance-service-name{font-weight:var(--weight-bold);color:var(--primary-dark);font-size:var(--text-base)}.attendance-service-date{font-size:var(--text-xs);color:var(--primary);margin-top:var(--space-1)}.attendance-summary-pills{gap:var(--space-2);flex-shrink:0;display:flex}.attendance-pill{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--weight-semibold);display:flex}.attendance-pill.present{background:var(--success-bg);color:var(--success-text)}.attendance-pill.absent{background:var(--danger-bg);color:var(--danger-text)}.attendance-filters{gap:var(--space-3);flex-wrap:wrap;align-items:center;display:flex}.attendance-member-list{border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;max-height:400px;display:flex;overflow:hidden auto}.attendance-member-row{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition-fast);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;display:flex}.attendance-member-row:last-child{border-bottom:none}.attendance-member-row:hover{background:var(--surface-2)}.attendance-member-row.present{background:#f0fdf4}.attendance-member-row.absent{background:var(--surface)}.attendance-member-left{align-items:center;gap:var(--space-3);display:flex}.member-group{color:var(--primary);font-weight:var(--weight-medium)}.attendance-toggle{transition:color var(--transition-fast);flex-shrink:0}.attendance-toggle.present{color:var(--success)}.attendance-toggle.absent{color:var(--danger)}.attendance-save-bar{padding-top:var(--space-4);border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.attendance-save-info{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--weight-medium)}@media (width<=768px){.attendance-stats-row{grid-template-columns:1fr}.service-card{flex-direction:column;align-items:flex-start}.service-card-actions{width:100%}.service-card-actions .btn-primary,.service-card-actions .btn-outline{justify-content:center;width:100%}.attendance-save-bar{flex-direction:column}}.finance-page{gap:var(--space-6);flex-direction:column;display:flex}.finance-summary-grid{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}.finance-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast), transform var(--transition-fast)}.finance-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.finance-stat-top{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.finance-stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:40px;height:40px;display:flex}.finance-stat-value{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--weight-extrabold);color:var(--text-primary);margin-bottom:var(--space-1);line-height:1}.finance-stat-label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary)}.finance-stat-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.finance-bottom{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.finance-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.finance-card-header{padding:var(--space-5) var(--space-5) var(--space-4);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.finance-card-header h3{font-size:var(--text-base);font-weight:var(--weight-bold);color:var(--text-primary)}.finance-card-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.offering-type-list{flex-direction:column;display:flex}.offering-type-card{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);transition:background var(--transition-fast);display:flex}.offering-type-card:last-child{border-bottom:none}.offering-type-card:hover{background:var(--surface-2)}.offering-type-dot{border-radius:var(--radius-full);flex-shrink:0;width:10px;height:10px}.offering-type-info{flex:1}.offering-type-label{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary)}.offering-type-count{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.offering-type-amount{font-family:var(--font-heading);font-size:var(--text-base);font-weight:var(--weight-bold);color:var(--text-primary)}.transaction-list{flex-direction:column;display:flex}.transaction-row{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:var(--space-3);transition:background var(--transition-fast);display:flex}.transaction-row:last-child{border-bottom:none}.transaction-row:hover{background:var(--surface-2)}.transaction-left{align-items:center;gap:var(--space-3);flex:1;min-width:0;display:flex}.transaction-type-dot{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.transaction-type{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary)}.transaction-meta{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;overflow:hidden}.transaction-amount{font-family:var(--font-heading);font-size:var(--text-base);font-weight:var(--weight-bold);color:var(--success);white-space:nowrap}@media (width<=1024px){.finance-summary-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.finance-summary-grid{grid-template-columns:1fr 1fr}.finance-bottom{grid-template-columns:1fr}}@media (width<=480px){.finance-summary-grid{grid-template-columns:1fr}}.departments-page{gap:var(--space-6);flex-direction:column;display:flex}.dept-summary-row{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.dept-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);align-items:center;gap:var(--space-4);box-shadow:var(--shadow-sm);display:flex}.dept-stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.dept-stat-value{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--weight-extrabold);color:var(--text-primary);line-height:1}.dept-stat-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.departments-list{gap:var(--space-4);flex-direction:column;display:flex}.dept-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.dept-card-header{padding:var(--space-5) var(--space-6);cursor:pointer;transition:background var(--transition-fast);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.dept-card-header:hover{background:var(--surface-2)}.dept-card-left{align-items:center;gap:var(--space-4);flex:1;min-width:0;display:flex}.dept-color-bar{border-radius:var(--radius-full);flex-shrink:0;width:4px;height:40px}.dept-name{font-size:var(--text-base);font-weight:var(--weight-bold);color:var(--text-primary)}.dept-description{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.dept-card-right{align-items:center;gap:var(--space-4);flex-shrink:0;display:flex}.dept-member-count,.dept-group-count{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--text-muted);font-weight:var(--weight-medium);display:flex}.dept-edit-btn{border-radius:var(--radius-md);width:30px;height:30px;color:var(--text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.dept-edit-btn:hover{background:var(--primary-light);color:var(--primary)}.dept-groups-section{border-top:1px solid var(--border);background:var(--surface-2);padding:var(--space-3) var(--space-6) var(--space-4)}.dept-empty-groups{padding:var(--space-3) 0;justify-content:space-between;align-items:center;display:flex}.dept-empty-groups p{font-size:var(--text-sm);color:var(--text-muted)}.cellgroup-card{padding:var(--space-3) var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-2);transition:box-shadow var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.cellgroup-card:hover{box-shadow:var(--shadow-sm)}.cellgroup-card-left{align-items:center;gap:var(--space-3);display:flex}.cellgroup-icon{border-radius:var(--radius-md);background:var(--primary-light);flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.cellgroup-name{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary)}.cellgroup-meta{gap:var(--space-3);font-size:var(--text-xs);color:var(--text-muted);margin-top:2px;display:flex}.cellgroup-edit-btn{border-radius:var(--radius-md);width:28px;height:28px;color:var(--text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.cellgroup-edit-btn:hover{background:var(--primary-light);color:var(--primary)}.dept-add-group-btn{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--primary);font-weight:var(--weight-medium);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1.5px dashed var(--primary);width:100%;margin-top:var(--space-2);cursor:pointer;transition:all var(--transition-fast);background:0 0;justify-content:center;display:flex}.dept-add-group-btn:hover{background:var(--primary-light)}.color-picker{gap:var(--space-2);flex-wrap:wrap;display:flex}.color-swatch{border-radius:var(--radius-full);cursor:pointer;width:32px;height:32px;transition:all var(--transition-fast);border:3px solid #0000}.color-swatch.selected{border-color:var(--text-primary);transform:scale(1.15)}.color-swatch:hover{transform:scale(1.1)}@media (width<=768px){.dept-summary-row{grid-template-columns:1fr}.dept-card-right{gap:var(--space-2)}.dept-member-count,.dept-group-count{display:none}.page-header{flex-direction:column}}.cellgroup-card-wrap{margin-bottom:var(--space-2)}.cellgroup-expanded{background:var(--bg);border:1px solid var(--border);border-radius:0 0 var(--radius-md) var(--radius-md);padding:var(--space-4);border-top:none}.cellgroup-leader-section{align-items:center;gap:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--border);margin-bottom:var(--space-3);display:flex}.cellgroup-leader-label{align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;display:flex}.cellgroup-leader-info{align-items:center;gap:var(--space-2);flex:1;display:flex}.cellgroup-leader-name{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary)}.cellgroup-action-link{font-size:var(--text-xs);color:var(--primary);font-weight:var(--weight-medium);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast);background:0 0;border:none;margin-left:auto;padding:2px 8px}.cellgroup-action-link:hover{background:var(--primary-light)}.cellgroup-empty-members{align-items:center;gap:var(--space-2);padding:var(--space-6);text-align:center;color:var(--text-muted);font-size:var(--text-sm);flex-direction:column;display:flex}.cellgroup-members-list{gap:var(--space-2);flex-direction:column;display:flex}.cellgroup-member-row{padding:var(--space-2) var(--space-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);transition:background var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.cellgroup-member-row:hover{background:var(--surface-2)}.cellgroup-member-left{align-items:center;gap:var(--space-3);display:flex}.cellgroup-member-name{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary);align-items:center;gap:var(--space-2);display:flex}.cellgroup-leader-badge{background:var(--warning-bg);color:var(--warning-text);border-radius:var(--radius-full);font-size:10px;font-weight:var(--weight-semibold);align-items:center;gap:3px;padding:1px 6px;display:inline-flex}.cellgroup-member-phone{font-size:var(--text-xs);color:var(--text-muted);display:block}.cellgroup-remove-btn{border-radius:var(--radius-md);width:26px;height:26px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.cellgroup-remove-btn:hover{background:var(--danger-bg);color:var(--danger)}.leader-select-list{gap:var(--space-2);max-height:350px;margin-top:var(--space-3);flex-direction:column;display:flex;overflow-y:auto}.leader-select-row{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1.5px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex}.leader-select-row:hover{background:var(--surface-2)}.leader-select-row.selected{border-color:var(--primary);background:var(--primary-light)}.confirm-modal-body{padding:var(--space-8) var(--space-6);text-align:center;align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.confirm-modal-icon{border-radius:var(--radius-full);background:var(--warning-bg);justify-content:center;align-items:center;width:56px;height:56px;display:flex}.confirm-modal-title{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--text-primary)}.confirm-modal-message{font-size:var(--text-sm);color:var(--text-secondary);max-width:280px}.confirm-modal-actions{gap:var(--space-3);margin-top:var(--space-2);justify-content:center;width:100%;display:flex}.btn-danger{align-items:center;gap:var(--space-2);padding:.625rem var(--space-4);background:var(--danger);color:#fff;border-radius:var(--radius-md);font-family:var(--font-heading);font-size:var(--text-sm);font-weight:var(--weight-semibold);cursor:pointer;transition:all var(--transition-fast);border:none;display:flex}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.reg-steps{justify-content:center;align-items:center;gap:0;display:flex}.reg-step-wrap{align-items:center;display:flex}.reg-step-dot{border-radius:var(--radius-full);border:2px solid var(--border);background:var(--surface);width:36px;height:36px;color:var(--text-muted);font-size:var(--text-sm);font-weight:var(--weight-bold);transition:all var(--transition-base);flex-shrink:0;justify-content:center;align-items:center;display:flex}.reg-step-dot.active{border-color:var(--primary);background:var(--primary);color:#fff}.reg-step-dot.done{border-color:var(--success);background:var(--success);color:#fff}.reg-step-line{background:var(--border);width:60px;height:2px;transition:background var(--transition-base)}.reg-step-line.done{background:var(--success)}.reg-step-content,.reg-step-header{margin-bottom:var(--space-6)}.reg-step-icon{border-radius:var(--radius-lg);background:var(--primary-light);width:48px;height:48px;margin-bottom:var(--space-4);justify-content:center;align-items:center;display:flex}.reg-step-title{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--weight-extrabold);color:var(--text-primary);margin-bottom:var(--space-1);letter-spacing:-.5px}.reg-step-sub{color:var(--text-secondary);font-size:var(--text-base)}.reg-form{gap:var(--space-4);flex-direction:column;display:flex}.reg-plan-info{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--success-bg);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--success-text);display:flex}.reg-nav-buttons{gap:var(--space-3);margin-bottom:var(--space-6);display:flex}.reg-back-btn{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.btn-login{flex:1}.reg-success{text-align:center;align-items:center;gap:var(--space-4);padding:var(--space-6) 0;flex-direction:column;display:flex}.reg-success-icon{border-radius:var(--radius-full);background:var(--success-bg);justify-content:center;align-items:center;width:80px;height:80px;display:flex}.reg-success-features{gap:var(--space-3);text-align:left;width:100%;margin-top:var(--space-2);flex-direction:column;display:flex}.reg-success-feature{align-items:center;gap:var(--space-3);font-size:var(--text-sm);color:var(--text-secondary);display:flex}@media (width<=768px){.reg-step-line{width:32px}}.settings-page{gap:var(--space-6);flex-direction:column;display:flex}.settings-tabs{gap:var(--space-1);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-2);box-shadow:var(--shadow-sm);flex-wrap:wrap;display:flex}.settings-tab{align-items:center;gap:var(--space-2);padding:.625rem var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;display:flex}.settings-tab:hover{background:var(--surface-2);color:var(--text-primary)}.settings-tab.active{background:var(--primary);color:#fff;font-weight:var(--weight-semibold)}.settings-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.settings-section{padding:var(--space-6);gap:var(--space-6);flex-direction:column;display:flex}.settings-section-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);padding-bottom:var(--space-5);border-bottom:1px solid var(--border);display:flex}.settings-section-title{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--text-primary)}.settings-section-sub{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}.settings-profile-grid{gap:var(--space-5);grid-template-columns:1fr 1fr;display:grid}.settings-field-label{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-2)}.settings-field-value{font-size:var(--text-base);color:var(--text-primary);font-weight:var(--weight-medium)}.settings-users-list{border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;display:flex;overflow:hidden}.settings-user-row{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);transition:background var(--transition-fast);display:flex}.settings-user-row:last-child{border-bottom:none}.settings-user-row:hover{background:var(--surface-2)}.settings-user-avatar{border-radius:var(--radius-full);background:var(--primary);color:#fff;width:40px;height:40px;font-family:var(--font-heading);font-weight:var(--weight-bold);font-size:var(--text-base);flex-shrink:0;justify-content:center;align-items:center;display:flex}.settings-user-info{flex:1;min-width:0}.settings-user-name{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary)}.settings-user-email{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.settings-user-joined{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap}.settings-trial-banner{align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--warning-bg);border-radius:var(--radius-md);border:1px solid #fde68a;display:flex}.settings-current-plan{padding:var(--space-4) var(--space-5);background:var(--surface-2);border-radius:var(--radius-md);border:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.settings-plans-grid{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.settings-plan-card{padding:var(--space-5);border:2px solid var(--border);border-radius:var(--radius-lg);gap:var(--space-2);transition:all var(--transition-fast);flex-direction:column;display:flex}.settings-plan-card:hover{box-shadow:var(--shadow-md)}.settings-plan-card.current{border-color:var(--primary);background:var(--primary-light)}.settings-plan-dot{border-radius:var(--radius-full);width:12px;height:12px}.settings-plan-name{font-size:var(--text-base);font-weight:var(--weight-bold);color:var(--text-primary)}.settings-plan-price{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--weight-extrabold);color:var(--text-primary)}.settings-plan-members{font-size:var(--text-xs);color:var(--text-muted)}.settings-plan-current-badge{margin-top:var(--space-3);background:var(--primary);color:#fff;text-align:center;border-radius:999px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.settings-security-form{max-width:480px}@media (width<=768px){.settings-tabs{gap:var(--space-1)}.settings-tab span{display:none}.settings-profile-grid,.settings-plans-grid{grid-template-columns:1fr}.settings-user-joined{display:none}}.reports-page{gap:var(--space-6);flex-direction:column;display:flex}.reports-content{gap:var(--space-4);flex-direction:column;display:flex}.report-stats-grid{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.report-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast), transform var(--transition-fast)}.report-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.report-stat-top{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.report-stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:40px;height:40px;display:flex}.report-stat-value{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--weight-extrabold);color:var(--text-primary);margin-bottom:var(--space-1);line-height:1}.report-stat-label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary)}.report-stat-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.reports-grid-2{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.report-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.report-card-header{padding:var(--space-5) var(--space-5) var(--space-4);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.report-card-header h3{font-size:var(--text-base);font-weight:var(--weight-bold);color:var(--text-primary)}.bar-chart{justify-content:space-around;align-items:flex-end;gap:var(--space-3);padding:var(--space-5);height:200px;display:flex}.bar-chart-item{align-items:center;gap:var(--space-1);flex-direction:column;flex:1;height:100%;display:flex}.bar-chart-bar-wrap{flex:1;align-items:flex-end;width:100%;display:flex}.bar-chart-bar{border-radius:var(--radius-sm) var(--radius-sm) 0 0;width:100%;min-height:4px;transition:height .8s}.bar-chart-value{font-size:10px;font-weight:var(--weight-semibold);color:var(--text-secondary);text-align:center}.bar-chart-label{color:var(--text-muted);text-align:center;white-space:nowrap;font-size:10px}.donut-chart-wrap{align-items:center;gap:var(--space-6);padding:var(--space-5);display:flex}.donut-svg{flex-shrink:0;width:140px;height:140px}.donut-legend{gap:var(--space-3);flex-direction:column;flex:1;display:flex}.donut-legend-item{align-items:center;gap:var(--space-2);display:flex}.donut-legend-dot{border-radius:var(--radius-full);flex-shrink:0;width:10px;height:10px}.donut-legend-label{font-size:var(--text-sm);color:var(--text-secondary);text-transform:capitalize;flex:1}.donut-legend-value{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-primary)}.report-table-wrap{overflow-x:auto}.report-table{border-collapse:collapse;width:100%}.report-table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap}.report-table td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);border-bottom:1px solid var(--border);vertical-align:middle}.report-table tr:last-child td{border-bottom:none}.report-table tr:hover td{background:var(--surface-2)}.top-list{gap:var(--space-3);padding:var(--space-4);flex-direction:column;display:flex}.top-list-item{align-items:center;gap:var(--space-3);display:flex}.top-list-rank{border-radius:var(--radius-md);background:var(--primary-light);width:28px;height:28px;color:var(--primary);font-size:var(--text-xs);font-weight:var(--weight-bold);flex-shrink:0;justify-content:center;align-items:center;display:flex}.report-avg-banner{align-items:center;gap:var(--space-4);padding:var(--space-5) var(--space-6);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex}@media (width<=1024px){.report-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.report-stats-grid{grid-template-columns:1fr 1fr}.reports-grid-2{grid-template-columns:1fr}.donut-chart-wrap{flex-direction:column}.bar-chart{height:160px}}@media (width<=480px){.report-stats-grid{grid-template-columns:1fr}}.events-page{gap:var(--space-6);flex-direction:column;display:flex}.events-stats-row{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}.events-view-toggle{background:var(--surface-2);border-radius:var(--radius-md);border:1px solid var(--border);padding:3px;display:flex}.events-toggle-btn{align-items:center;gap:var(--space-1);border-radius:calc(var(--radius-md) - 2px);font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;padding:5px 14px;display:flex}.events-toggle-btn.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}.calendar-nav{padding:var(--space-2);justify-content:space-between;align-items:center;display:flex}.calendar-month-title{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--text-primary)}.calendar-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.calendar-grid-header{background:var(--surface-2);border-bottom:1px solid var(--border);grid-template-columns:repeat(7,1fr);display:grid}.calendar-day-header{padding:var(--space-3);text-align:center;font-size:var(--text-xs);font-weight:var(--weight-bold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.calendar-grid{grid-template-columns:repeat(7,1fr);display:grid}.calendar-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);min-height:100px;padding:var(--space-2);transition:background var(--transition-fast);position:relative}.calendar-cell:nth-child(7n){border-right:none}.calendar-cell:hover:not(.calendar-cell-empty){background:var(--surface-2)}.calendar-cell-empty{background:var(--surface-2);opacity:.5}.calendar-cell-today{background:var(--primary-light)!important}.calendar-cell-past{opacity:.7}.calendar-day-num{border-radius:var(--radius-full);width:26px;height:26px;font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-secondary);justify-content:center;align-items:center;margin-bottom:4px;display:inline-flex}.calendar-cell-today .calendar-day-num{background:var(--primary);color:#fff}.calendar-day-events{flex-direction:column;gap:2px;display:flex}.calendar-event-pill{font-size:10px;font-weight:var(--weight-semibold);color:#fff;white-space:nowrap;text-overflow:ellipsis;cursor:pointer;transition:opacity var(--transition-fast);border-radius:3px;padding:2px 6px;overflow:hidden}.calendar-event-pill:hover{opacity:.85}.calendar-more-pill{color:var(--text-muted);font-size:10px;font-weight:var(--weight-semibold);padding:0 2px}.event-list{gap:var(--space-3);flex-direction:column;display:flex}.event-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast), transform var(--transition-fast);display:flex;overflow:hidden}.event-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.event-card-stripe{flex-shrink:0;width:4px}.event-card-body{padding:var(--space-4) var(--space-5);flex:1}.event-card-header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-2);display:flex}.event-card-title{font-size:var(--text-base);font-weight:var(--weight-bold);color:var(--text-primary)}.event-card-meta{gap:var(--space-2);margin-bottom:var(--space-3);flex-wrap:wrap;display:flex}.event-card-info{gap:var(--space-4);font-size:var(--text-xs);color:var(--text-secondary);flex-wrap:wrap;display:flex}@media (width<=768px){.events-stats-row{grid-template-columns:repeat(2,1fr)}.calendar-cell{min-height:64px}.events-page [style*="grid-template-columns: 1fr 300px"]{grid-template-columns:1fr!important}.stat-grid{grid-template-columns:repeat(2,1fr)!important}.dashboard-bottom,[style*="grid-template-columns: 1fr 1fr 1fr"]{flex-direction:column!important;display:flex!important}.dashboard-header{align-items:flex-start;gap:var(--space-3);flex-direction:column}.dashboard-header .btn-primary{justify-content:center;width:100%}.finance-summary-grid{grid-template-columns:repeat(2,1fr)!important}.finance-bottom,[style*="grid-template-columns: 1fr 1fr 1fr"]{grid-template-columns:1fr!important}.dept-summary-row,.events-stats-row{grid-template-columns:repeat(2,1fr)!important}[style*="grid-template-columns: 1fr 300px"],[style*="grid-template-columns: 1fr 320px"]{flex-direction:column!important;display:flex!important}.report-stats-grid{grid-template-columns:repeat(2,1fr)!important}.reports-grid-2{grid-template-columns:1fr!important}.attendance-stats-row{grid-template-columns:repeat(2,1fr)!important}.page-header{align-items:flex-start;gap:var(--space-3);flex-direction:column}.page-header>div:last-child{gap:var(--space-2);flex-wrap:wrap;width:100%;display:flex}.page-header .btn-primary,.page-header .btn-outline{flex:1;justify-content:center;min-width:120px}.calendar-cell{min-height:54px;padding:2px}.calendar-event-pill{padding:1px 3px;font-size:8px}.calendar-day-num{width:20px;height:20px;font-size:11px}.table-wrap{display:none}.member-cards-list{display:flex!important}.audit-cards-list{padding:var(--space-3);display:block}.audit-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-3);box-shadow:var(--shadow-xs)}.audit-card-row{justify-content:space-between;gap:var(--space-2);margin-bottom:var(--space-2);display:flex}.audit-time{color:var(--text-secondary);font-size:12px}.audit-user{font-weight:600}.audit-action-row{justify-content:space-between;gap:var(--space-2);margin-bottom:var(--space-1);display:flex}.audit-action{color:var(--primary)}.audit-desc{color:var(--text);font-size:13px}.filters-bar,.filter-selects{flex-direction:column}.form-row{grid-template-columns:1fr!important}.modal{margin:var(--space-4);max-height:85vh}.service-card{flex-direction:column;align-items:flex-start}.service-card-actions{width:100%}.service-card-actions .btn-primary,.service-card-actions .btn-outline{justify-content:center;width:100%}.health-score-body{flex-direction:column;align-items:flex-start}.settings-tabs{padding-bottom:var(--space-1);overflow-x:auto}.success-toast{right:var(--space-3);left:var(--space-3);justify-content:center}}@media (width<=480px){.stat-grid,.finance-summary-grid,.dept-summary-row,.events-stats-row,.attendance-stats-row{grid-template-columns:1fr 1fr!important}.mobile-content{padding:var(--space-3)}.stat-card{min-width:0;overflow:hidden}.stat-card-label{white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.stat-card-sublabel{white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.stat-card-value{font-size:var(--text-2xl)}}.dashboard-bottom-grid{gap:var(--space-4);grid-template-columns:1fr 1fr 1fr;display:grid}.compose-grid{gap:var(--space-5);grid-template-columns:1fr 320px;align-items:start;display:grid}.finance-net-strip{gap:var(--space-4);padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);grid-template-columns:1fr 1fr 1fr;display:grid}.finance-net-strip.profit{background:#f0fdf4;border:1px solid #bbf7d0}.finance-net-strip.deficit{background:#fef2f2;border:1px solid #fecaca}.events-list-grid{gap:var(--space-5);grid-template-columns:1fr 300px;align-items:start;display:grid}.report-net-banner{padding:var(--space-5) var(--space-6);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.report-net-banner.profit{background:#f0fdf4;border:1px solid #bbf7d0}.report-net-banner.deficit{background:#fef2f2;border:1px solid #fecaca}@media (width<=1024px){.dashboard-bottom-grid{grid-template-columns:1fr 1fr}.compose-grid{grid-template-columns:1fr}.finance-net-strip{grid-template-columns:1fr 1fr}.events-list-grid{grid-template-columns:1fr}}@media (width<=768px){.dashboard-bottom-grid{grid-template-columns:1fr}.dashboard-greeting{font-size:var(--text-xl)}.stat-grid{grid-template-columns:1fr 1fr}.compose-grid{grid-template-columns:1fr}.finance-net-strip{gap:var(--space-3);grid-template-columns:1fr}.finance-summary-grid{grid-template-columns:1fr 1fr}.finance-bottom,.events-list-grid{grid-template-columns:1fr}.events-stats-row{grid-template-columns:1fr 1fr}.event-card-header{align-items:flex-start;gap:var(--space-2);flex-direction:column}.event-card-info{gap:var(--space-2)}.report-net-banner{flex-direction:column;align-items:flex-start}.report-net-banner>div:last-child{text-align:left}.report-stats-grid{grid-template-columns:1fr 1fr}.reports-grid-2{grid-template-columns:1fr}.attendance-stats-row{grid-template-columns:1fr 1fr}.service-card{align-items:flex-start;gap:var(--space-3);flex-direction:column}.service-card-actions{width:100%}.service-card-actions .btn-primary,.service-card-actions .btn-outline{justify-content:center;width:100%}.dept-summary-row{grid-template-columns:1fr 1fr}.dept-card-right{gap:var(--space-2)}.filters-bar{flex-direction:column}.filter-selects{flex-direction:column;width:100%}.filter-select,.search-input{width:100%}.settings-tabs{padding-bottom:var(--space-1);flex-wrap:nowrap;overflow-x:auto}.settings-profile-grid,.settings-plans-grid{grid-template-columns:1fr}.page-header{align-items:flex-start;gap:var(--space-3);flex-direction:column}.page-header>div:last-child{gap:var(--space-2);flex-wrap:wrap;width:100%;display:flex}.page-header .btn-primary,.page-header .btn-outline{flex:1;justify-content:center;min-width:120px}.modal{margin:var(--space-3);max-height:92vh}.modal-body{padding:var(--space-4)}.form-row{grid-template-columns:1fr}.calendar-cell{min-height:54px;padding:2px}.calendar-event-pill{padding:1px 3px;font-size:9px}.calendar-day-num{width:20px;height:20px;font-size:11px}.health-score-body{flex-direction:column;align-items:flex-start}.health-factor-label{width:100px}.success-toast{right:var(--space-3);left:var(--space-3);justify-content:center}.donut-chart-wrap{flex-direction:column;align-items:center}}@media (width<=480px){.stat-grid{grid-template-columns:1fr 1fr}.stat-card-value{font-size:var(--text-2xl)}.stat-card-label{font-size:11px}.finance-summary-grid,.events-stats-row,.attendance-stats-row,.dept-summary-row,.report-stats-grid{grid-template-columns:1fr 1fr}.mobile-content{padding:var(--space-3);padding-bottom:calc(var(--bottom-nav-height) + var(--space-3))}.page-title{font-size:var(--text-xl)}.dashboard-greeting{font-size:var(--text-lg)}}@media (width<=1024px){.pledges-stats-grid,.pledges-grid{grid-template-columns:repeat(2,1fr)!important}}@media (width<=768px){.pledges-stats-grid{grid-template-columns:repeat(2,1fr)!important}.pledges-grid{grid-template-columns:1fr!important}}.automations-page{gap:var(--space-6);flex-direction:column;display:flex}.auto-info-banner{align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--primary-light);border:1px solid var(--primary);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;display:flex}.auto-stats-row{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.auto-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.auto-cards-grid{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.auto-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast), border-color var(--transition-fast);flex-direction:column;display:flex;overflow:hidden}.auto-card:hover{box-shadow:var(--shadow-md)}.auto-card--active{border-color:var(--success)}.auto-card-header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);padding:var(--space-5);display:flex}.auto-card-left{align-items:flex-start;gap:var(--space-4);flex:1;min-width:0;display:flex}.auto-card-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.auto-card-name{font-size:var(--text-base);color:var(--text-primary);margin-bottom:var(--space-1);font-weight:700;line-height:1.3}.auto-card-desc{font-size:var(--text-xs);color:var(--text-muted);line-height:1.5}.auto-toggle-btn{cursor:pointer;transition:transform var(--transition-fast);background:0 0;border:none;flex-shrink:0;align-items:center;padding:0;display:flex}.auto-toggle-btn:hover:not(:disabled){transform:scale(1.08)}.auto-toggle-btn:disabled{opacity:.5;cursor:not-allowed}.auto-card-stats{align-items:center;gap:var(--space-4);padding:0 var(--space-5) var(--space-3);flex-wrap:wrap;display:flex}.auto-stat{align-items:center;gap:var(--space-1);color:var(--text-muted);font-size:11px;display:flex}.auto-expand-btn{align-items:center;gap:var(--space-2);margin:0 var(--space-5) var(--space-3);color:var(--primary);cursor:pointer;padding:var(--space-1) 0;background:0 0;border:none;width:fit-content;font-size:11px;font-weight:600;display:flex}.auto-expand-btn:hover{text-decoration:underline}.auto-message-preview{margin:0 var(--space-5) var(--space-3);padding:var(--space-3) var(--space-4);background:var(--surface-2);border-radius:var(--radius-md);border-left:3px solid var(--primary)}.auto-card-actions{gap:var(--space-2);padding:var(--space-4) var(--space-5);border-top:1px solid var(--border);background:var(--surface-2);margin-top:auto;display:flex}.auto-action-btn{align-items:center;gap:var(--space-1);padding:.5rem var(--space-3);font-size:var(--text-xs);font-weight:600;display:flex}@media (width<=768px){.auto-cards-grid{grid-template-columns:1fr}.auto-stats-row{grid-template-columns:1fr 1fr 1fr}.auto-card-actions{flex-wrap:wrap}}@media (width<=480px){.auto-stats-row{grid-template-columns:1fr}}.forgot-success{text-align:center;padding:16px 0}.forgot-success-icon{margin-bottom:16px;font-size:48px}.forgot-success h2{color:var(--text-primary);margin-bottom:12px;font-size:24px;font-weight:700}.forgot-success p{color:var(--text-muted);margin-bottom:8px;line-height:1.6}.forgot-success-note{color:var(--text-muted);font-size:13px}.password-strength{align-items:center;gap:10px;margin-top:8px;display:flex}.password-strength-bar{background:var(--border-color,#e5e7eb);border-radius:999px;flex:1;height:4px;overflow:hidden}.password-strength-fill{border-radius:999px;height:100%;transition:width .3s,background .3s}.password-strength span{min-width:60px;font-size:12px;font-weight:500}.reset-redirect-bar{background:var(--border-color,#e5e7eb);border-radius:999px;height:3px;margin-top:24px;overflow:hidden}.reset-redirect-progress{background:#f97316;border-radius:999px;height:100%;animation:2s linear forwards progressFill}@keyframes progressFill{0%{width:0%}to{width:100%}}@media (width<=768px){.settings-tab span{white-space:nowrap;font-size:11px;display:inline!important}.settings-tabs{padding-bottom:var(--space-2);-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;overflow-x:auto}.settings-tabs::-webkit-scrollbar{display:none}.settings-tab{min-width:fit-content;padding:.5rem var(--space-3);font-size:var(--text-xs);flex-shrink:0}}.app-loading{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.app-loading-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.desktop-layout{background:var(--bg);min-height:100vh;display:flex}.desktop-main{min-width:0;margin-left:var(--sidebar-width);flex-direction:column;flex:1;display:flex}.desktop-content{padding:var(--space-8);padding-top:calc(var(--navbar-height) + var(--space-8));max-width:var(--container-max);width:100%;animation:fadeIn var(--transition-base) ease;flex:1}.mobile-layout{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.mobile-content{padding:var(--space-4);padding-bottom:calc(var(--bottom-nav-height) + var(--space-4));margin-top:var(--navbar-height);animation:fadeIn var(--transition-base) ease;flex:1}.sidebar{width:var(--sidebar-width);background:var(--surface);border-right:1px solid var(--border);height:100vh;z-index:var(--z-sidebar);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-logo{align-items:center;gap:var(--space-3);padding:var(--space-6) var(--space-5);border-bottom:1px solid var(--border);display:flex}.brand-logo{align-items:center;gap:var(--space-3);display:flex}.brand-logo-image,.brand-logo-fallback{border-radius:var(--radius-md);background:var(--surface);flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.brand-logo-image{object-fit:contain;background:#fff;padding:6px}.brand-logo-fallback{background:var(--primary)}.brand-logo-text{flex-direction:column;min-width:0;display:flex}.brand-logo-title{font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--text-primary);margin-bottom:2px}.brand-logo-subtitle{font-size:var(--text-xs);color:var(--text-muted);line-height:1.2}.sidebar-logo-icon{background:var(--primary);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.sidebar-logo-title{font-family:var(--font-heading);font-size:var(--text-base);font-weight:var(--weight-bold);color:var(--text-primary);line-height:1.2}.sidebar-logo-church{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:160px;margin-top:2px;overflow:hidden}.sidebar-nav{padding:var(--space-4) var(--space-3);gap:var(--space-1);flex-direction:column;flex:1;display:flex}.sidebar-nav-label{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-2) var(--space-3);margin-bottom:var(--space-1)}.sidebar-nav-item{align-items:center;gap:var(--space-3);padding:.625rem var(--space-3);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--weight-medium);transition:all var(--transition-fast);cursor:pointer;display:flex}.sidebar-nav-item:hover{background:var(--surface-2);color:var(--text-primary)}.sidebar-nav-item.active{background:var(--primary-light);color:var(--primary);font-weight:var(--weight-semibold)}.sidebar-nav-item.active svg{color:var(--primary)}.sidebar-footer{padding:var(--space-4) var(--space-3);border-top:1px solid var(--border);align-items:center;gap:var(--space-3);display:flex}.sidebar-user{align-items:center;gap:var(--space-3);flex:1;min-width:0;display:flex}.sidebar-user-avatar{border-radius:var(--radius-full);background:var(--primary-light);width:36px;height:36px;color:var(--primary);font-family:var(--font-heading);font-weight:var(--weight-bold);font-size:var(--text-sm);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-user-info{min-width:0}.sidebar-user-name{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-user-role{font-size:var(--text-xs);color:var(--text-muted);text-transform:capitalize}.sidebar-logout{border-radius:var(--radius-md);width:34px;height:34px;color:var(--text-muted);transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logout:hover{background:var(--danger-bg);color:var(--danger)}.navbar{height:var(--navbar-height);background:var(--surface);border-bottom:1px solid var(--border);padding:0 var(--space-6);top:0;right:0;left:var(--sidebar-width);z-index:var(--z-navbar);justify-content:space-between;align-items:center;display:flex;position:fixed}.navbar-left{align-items:center;gap:var(--space-4);display:flex}.navbar-menu-btn{border-radius:var(--radius-md);width:38px;height:38px;color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:none}.navbar-menu-btn:hover{background:var(--surface-2)}.navbar-church-name{font-family:var(--font-heading);font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--text-primary);line-height:1.2}.navbar-church-plan{font-size:var(--text-xs);color:var(--text-muted)}.navbar-right{align-items:center;gap:var(--space-2);display:flex}.navbar-icon-btn{border-radius:var(--radius-md);width:38px;height:38px;color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:relative}.navbar-icon-btn:hover{background:var(--surface-2);color:var(--text-primary)}.navbar-badge{background:var(--danger);color:#fff;width:16px;height:16px;font-size:9px;font-weight:var(--weight-bold);border-radius:var(--radius-full);justify-content:center;align-items:center;display:flex;position:absolute;top:6px;right:6px}.navbar-avatar{border-radius:var(--radius-full);background:var(--primary);color:#fff;width:36px;height:36px;font-family:var(--font-heading);font-weight:var(--weight-bold);font-size:var(--text-sm);cursor:pointer;margin-left:var(--space-2);justify-content:center;align-items:center;display:flex}.bottom-nav{height:var(--bottom-nav-height);background:var(--surface);border-top:1px solid var(--border);padding:0 var(--space-2);z-index:var(--z-navbar);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--text-muted);font-size:10px;font-weight:var(--weight-medium);transition:all var(--transition-fast);cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:4px;min-width:56px;display:flex}.bottom-nav-item:hover,.bottom-nav-item.active,.bottom-nav-item.active svg{color:var(--primary)}.drawer-overlay{z-index:var(--z-overlay);opacity:0;pointer-events:none;transition:opacity var(--transition-base);background:#00000080;position:fixed;inset:0}.drawer-overlay.open{opacity:1;pointer-events:all}.drawer{width:var(--sidebar-width);height:100vh;z-index:calc(var(--z-overlay) + 1);transition:transform var(--transition-base);position:fixed;top:0;left:0;transform:translate(-100%)}.drawer.open{transform:translate(0)}.page-placeholder{min-height:60vh;font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--text-muted);background:var(--surface);border-radius:var(--radius-lg);border:2px dashed var(--border);justify-content:center;align-items:center;display:flex}@media (width<=768px){.sidebar,.desktop-layout{display:none}.navbar{left:0}.navbar-menu-btn{display:flex}.desktop-content{padding:var(--space-4)}}@media (width<=480px){.navbar-church-name{font-size:var(--text-sm);white-space:nowrap;text-overflow:ellipsis;max-width:140px;overflow:hidden}.navbar{padding:0 var(--space-3)}}.bottom-nav{z-index:999;box-shadow:0 -2px 12px #00000014}.drawer .sidebar{display:flex!important}.navbar-icon-btn--active{background:var(--primary-light)!important;color:var(--primary)!important}.navbar-avatar--active{outline:3px solid var(--primary);outline-offset:2px}.search-modal-overlay{z-index:var(--z-modal);background:#00000073;justify-content:center;align-items:flex-start;padding-top:80px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.search-modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:560px;animation:.2s slideUp;overflow:hidden}.search-modal-input-wrap{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);display:flex}.search-modal-input{font-size:var(--text-base);color:var(--text-primary);font-family:var(--font-body);background:0 0;border:none;outline:none;flex:1}.search-modal-input::placeholder{color:var(--text-muted)}.search-modal-spinner{border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite spin}.search-modal-clear{border-radius:var(--radius-full);width:24px;height:24px;color:var(--text-muted);background:var(--surface-2);cursor:pointer;transition:all var(--transition-fast);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.search-modal-clear:hover{background:var(--border);color:var(--text-primary)}.search-results{max-height:400px;overflow-y:auto}.search-result-group{padding:var(--space-2) 0}.search-result-group-label{align-items:center;gap:var(--space-2);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-2) var(--space-5) var(--space-1);font-size:10px;font-weight:800;display:flex}.search-result-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);cursor:pointer;transition:background var(--transition-fast);display:flex}.search-result-item:hover{background:var(--surface-2)}.search-result-avatar{border-radius:var(--radius-full);background:var(--primary-light);width:36px;height:36px;color:var(--primary);font-size:var(--text-sm);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.search-result-info{flex:1;min-width:0}.search-result-name{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.search-result-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:1px}.search-no-results{align-items:center;gap:var(--space-2);padding:var(--space-10);color:var(--text-muted);font-size:var(--text-sm);text-align:center;flex-direction:column;display:flex}.search-hint{padding:var(--space-3) var(--space-5);font-size:var(--text-xs);color:var(--text-muted);background:var(--surface-2);justify-content:space-between;align-items:center;display:flex}.search-hint kbd{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);padding:2px 8px;font-family:monospace;font-size:11px}.notif-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:340px;box-shadow:var(--shadow-xl);z-index:var(--z-dropdown);animation:.2s slideUp;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}.notif-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.notif-title{font-size:var(--text-sm);color:var(--text-primary);font-weight:700}.notif-count-badge{border-radius:var(--radius-full);background:var(--primary);color:#fff;padding:2px 7px;font-size:10px;font-weight:700}.notif-body{max-height:360px;overflow-y:auto}.notif-loading{padding:var(--space-8);justify-content:center;align-items:center;display:flex}.notif-item{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--border);transition:background var(--transition-fast);cursor:default;display:flex}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--surface-2)}.notif-birthday{background:#fffbeb}[data-theme=dark] .notif-birthday{background:#f59e0b14}.notif-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.notif-info{flex:1;min-width:0}.notif-text{font-size:var(--text-xs);color:var(--text-primary);line-height:1.5}.notif-time{color:var(--text-muted);margin-top:2px;font-size:10px}.notif-empty{align-items:center;gap:var(--space-2);padding:var(--space-10);color:var(--text-muted);font-size:var(--text-sm);flex-direction:column;display:flex}.notif-footer{padding:var(--space-3) var(--space-5);border-top:1px solid var(--border);background:var(--surface-2);text-align:center}.profile-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:260px;box-shadow:var(--shadow-xl);z-index:var(--z-dropdown);animation:.2s slideUp;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}.profile-dropdown-header{align-items:center;gap:var(--space-3);padding:var(--space-5);display:flex}.profile-dropdown-avatar{border-radius:var(--radius-full);background:var(--primary);color:#fff;width:44px;height:44px;font-family:var(--font-heading);font-weight:800;font-size:var(--text-lg);flex-shrink:0;justify-content:center;align-items:center;display:flex}.profile-dropdown-info{min-width:0}.profile-dropdown-name{font-size:var(--text-sm);color:var(--text-primary);font-weight:700;line-height:1.3}.profile-dropdown-role{font-size:var(--text-xs);color:var(--primary);text-transform:capitalize;margin-top:1px;font-weight:600}.profile-dropdown-church{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;overflow:hidden}.profile-dropdown-divider{background:var(--border);height:1px;margin:0}.profile-dropdown-menu{padding:var(--space-2)}.profile-dropdown-item{align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;text-align:left;transition:all var(--transition-fast);background:0 0;border:none;font-weight:500;display:flex}.profile-dropdown-item:hover{background:var(--surface-2);color:var(--text-primary)}.profile-dropdown-logout{align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--danger);cursor:pointer;text-align:left;transition:all var(--transition-fast);background:0 0;border:none;font-weight:600;display:flex}.profile-dropdown-logout:hover{background:var(--danger-bg)}@media (width<=480px){.notif-dropdown,.profile-dropdown{width:calc(100vw - var(--space-6));right:calc(-1 * var(--space-3))}.search-modal-overlay{padding-top:60px;padding-left:var(--space-3);padding-right:var(--space-3)}}.branch-switcher{position:relative}.branch-switcher-btn{align-items:center;gap:var(--space-2);padding:5px var(--space-3);background:var(--primary-light);border:1.5px solid var(--primary);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);max-width:200px;display:flex}.branch-switcher-btn:hover{background:var(--primary)}.branch-switcher-btn:hover .branch-switcher-name{color:#fff}.branch-switcher-btn:hover svg{color:#fff!important}.branch-switcher-name{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--primary);white-space:nowrap;text-overflow:ellipsis;max-width:130px;overflow:hidden}.branch-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:260px;box-shadow:var(--shadow-xl);z-index:var(--z-dropdown);animation:.2s slideUp;position:absolute;top:calc(100% + 8px);left:0;overflow:hidden}.branch-dropdown-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-3) var(--space-4) var(--space-1);font-size:10px;font-weight:800}.branch-dropdown-item{align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);cursor:pointer;text-align:left;transition:background var(--transition-fast);background:0 0;border:none;display:flex}.branch-dropdown-item:hover{background:var(--surface-2)}.branch-dropdown-item.active{background:var(--primary-light)}.branch-dropdown-icon{flex-shrink:0;font-size:18px}.branch-dropdown-info{flex:1;min-width:0}.branch-dropdown-name{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary);align-items:center;gap:var(--space-2);display:flex}.branch-dropdown-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:1px}.branch-main-badge{border-radius:var(--radius-full);background:var(--primary);color:#fff;text-transform:uppercase;letter-spacing:.04em;padding:1px 6px;font-size:9px;font-weight:700}@media (width<=768px){.branch-switcher-name{max-width:80px}}
