@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Plus+Jakarta+Sans:wght@500;600;700;800&display=swap";:root{--primary:#002e5d;--primary-dark:#001f42;--primary-light:#1a5276;--primary-subtle:#002e5d14;--accent:#b78b20;--accent-dark:#946f18;--accent-light:#d4a843;--success:#2e7d32;--success-light:#e8f5e9;--warning:#ef8c22;--warning-light:#fff3e0;--danger:#c62828;--danger-light:#fce4ec;--info:#1565c0;--info-light:#e3f2fd;--bg-body:#f5f5f0;--bg-surface:#fff;--bg-surface-hover:#f8f8f5;--bg-card:#fff;--bg-input:#fafaf7;--bg-sidebar:#002e5d;--text-primary:#1a1a2e;--text-secondary:#4a4a5a;--text-muted:#8a8a9a;--text-inverse:#fff;--border:#002e5d26;--border-hover:#002e5d4d;--border-subtle:#e8e8e3;--glass-bg:#ffffffd9;--glass-border:#ddd8d0;--glass-shadow:0 4px 20px #0000000f;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:50%;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--sidebar-width:260px;--sidebar-collapsed:72px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:var(--bg-body);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}h1,h2,h3,h4,h5,h6{letter-spacing:-.025em;color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-weight:700;line-height:1.3}h1{font-size:1.75rem}h2{font-size:1.4rem}h3{font-size:1.15rem}h4{font-size:1rem}a{color:var(--primary-light);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent)}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);z-index:100;transition:transform var(--transition-base);border-right:none;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:2px 0 12px #0000001a}.sidebar-header{padding:var(--space-lg);align-items:center;gap:var(--space-md);border-bottom:1px solid #ffffff1f;display:flex}.sidebar-logo{border-radius:var(--radius-md);background:#ffffff26;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.sidebar-logo svg{color:#fff;width:20px;height:20px}.sidebar-title{color:#fff;font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:700}.sidebar-nav{padding:var(--space-md) var(--space-sm);flex:1;overflow-y:auto}.nav-section-label{text-transform:uppercase;letter-spacing:.08em;color:#ffffff73;padding:var(--space-lg) var(--space-md) var(--space-xs);font-size:.7rem;font-weight:600}.nav-link{align-items:center;gap:var(--space-md);padding:.6rem var(--space-md);border-radius:var(--radius-md);color:#ffffffb3;transition:all var(--transition-fast);cursor:pointer;margin-bottom:2px;font-size:.9rem;font-weight:500;text-decoration:none;display:flex}.nav-link:hover{color:#fff;background:#ffffff1a}.nav-link.active{color:#fff;background:#ffffff2e;font-weight:600}.nav-link.active svg{color:var(--accent-light)}.nav-link svg{opacity:.7;flex-shrink:0;width:18px;height:18px}.nav-link.active svg{opacity:1}.sidebar-footer{padding:var(--space-md);border-top:1px solid #ffffff1f}.sidebar-user{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);display:flex}.sidebar-user-avatar{border-radius:var(--radius-full);color:#fff;background:#fff3;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.8rem;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.sidebar-user-role{color:#ffffff8c;text-transform:capitalize;font-size:.7rem}.main-content{margin-left:var(--sidebar-width);padding:var(--space-xl);flex:1;min-height:100vh}.page-header{margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.page-header h1{align-items:center;gap:var(--space-sm);display:flex}.page-header h1 svg{color:var(--accent)}.page-actions,.section-actions,.action-row{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.action-row-end{justify-content:flex-end}.split-layout{gap:var(--space-lg);grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;display:grid}.split-layout-wide{grid-template-columns:minmax(280px,1fr) minmax(0,2fr)}.sticky-panel{top:var(--space-lg);position:sticky}.section-header{justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);flex-wrap:wrap;display:flex}.inline-stack{flex-direction:column;gap:.75rem;display:flex}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow)}.glass-panel-padded{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);padding:var(--space-lg)}.card{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base)}.card:hover{border-color:var(--border-hover);box-shadow:0 4px 20px #002e5d26}.card-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s,border-color .15s}.card-clickable:hover{transform:translateY(-2px);box-shadow:0 6px 24px #002e5d2e}.card-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.card-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:.85rem;font-weight:600}.card-value{background:linear-gradient(135deg, var(--text-primary), var(--accent-light));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-family:Plus Jakarta Sans,sans-serif;font-size:2rem;font-weight:800}.card-subtitle{color:var(--text-muted);margin-top:var(--space-xs);font-size:.8rem}.stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:40px;height:40px;display:flex}.stat-icon.purple{color:var(--primary-light);background:#002e5d33}.stat-icon.gold{color:var(--accent);background:#d4a84333}.stat-icon.green{color:var(--success);background:#2e7d3233}.stat-icon.red{color:var(--danger);background:#d32f2f33}.stat-icon.blue{color:var(--info);background:#1976d233}.btn{align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;padding:.55rem 1.2rem;font-family:Inter,sans-serif;font-size:.875rem;font-weight:600;line-height:1.4;text-decoration:none;display:inline-flex}.btn svg{width:16px;height:16px}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;box-shadow:0 2px 8px #002e5d66}.btn-primary:hover{background:linear-gradient(135deg, var(--primary-light), var(--primary));transform:translateY(-1px);box-shadow:0 4px 16px #002e5d80}.btn-accent{background:linear-gradient(135deg, var(--accent), var(--accent-dark));color:var(--text-inverse);box-shadow:0 2px 8px #d4a84366}.btn-accent:hover{transform:translateY(-1px);box-shadow:0 4px 16px #d4a84380}.btn-ghost{color:var(--text-secondary);border:1px solid var(--glass-border);background:0 0}.btn-ghost:hover{background:var(--primary-subtle);color:var(--text-primary);border-color:var(--border-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#c62828}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-sm svg{width:14px;height:14px}.btn-icon{border-radius:var(--radius-sm);padding:.5rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.form-group{margin-bottom:var(--space-lg)}.form-label{color:var(--text-secondary);margin-bottom:var(--space-xs);font-size:.85rem;font-weight:600;display:block}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--glass-border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:all var(--transition-fast);padding:.6rem .85rem;font-family:Inter,sans-serif;font-size:.9rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #002e5d33}.form-input::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:80px}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a8a0b8' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;padding-right:2rem}.form-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.form-error{color:var(--danger);margin-top:var(--space-xs);font-size:.8rem}.data-table{border-collapse:separate;border-spacing:0;width:100%}.data-table th{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:1px solid var(--glass-border);white-space:nowrap;font-size:.75rem;font-weight:600}.data-table td{padding:.75rem var(--space-md);border-bottom:1px solid var(--border-subtle);vertical-align:middle;font-size:.9rem}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--primary-subtle)}.data-table tbody tr:last-child td{border-bottom:none}.desktop-table-wrapper{overflow:auto}.mobile-card-list{display:none}.mobile-record-card{padding:var(--space-lg)}.mobile-record-header{justify-content:space-between;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md);display:flex}.mobile-record-title{font-size:1rem;font-weight:700}.mobile-record-subtitle{color:var(--text-muted);margin-top:.15rem;font-size:.82rem}.mobile-record-fields{gap:var(--space-sm);display:grid}.mobile-record-field{gap:var(--space-sm);grid-template-columns:minmax(92px,120px) minmax(0,1fr);align-items:start;font-size:.88rem;display:grid}.mobile-record-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:600}.mobile-record-actions{gap:var(--space-sm);margin-top:var(--space-md);flex-wrap:wrap;display:flex}.status-pill{letter-spacing:.02em;white-space:nowrap;border-radius:100px;align-items:center;gap:6px;padding:.2rem .7rem;font-size:.75rem;font-weight:600;display:inline-flex}.status-pill:before{content:"";border-radius:50%;flex-shrink:0;width:6px;height:6px}.status-pill.new{background:var(--info-light);color:#1565c0}.status-pill.new:before{background:#1976d2}.status-pill.work_in_progress,.status-pill.in_progress{background:var(--warning-light);color:#e65100}.status-pill.work_in_progress:before,.status-pill.in_progress:before{background:var(--warning)}.status-pill.complete,.status-pill.completed{background:var(--success-light);color:#1b5e20}.status-pill.complete:before,.status-pill.completed:before{background:var(--success)}.status-pill.pending{color:var(--text-muted);background:#6b638026}.status-pill.pending:before{background:var(--text-muted)}.status-pill.skipped{color:var(--text-muted);background:#6b63801a}.status-pill.skipped:before{background:var(--text-muted)}.status-pill.active{background:var(--primary-subtle);color:var(--primary-light)}.status-pill.active:before{background:var(--primary-light)}.status-pill.cancelled{background:var(--danger-light);color:var(--danger)}.status-pill.cancelled:before{background:var(--danger)}.action-badge{border-radius:var(--radius-sm);white-space:nowrap;align-items:center;gap:4px;padding:.2rem .55rem;font-size:.72rem;font-weight:600;display:inline-flex}.action-badge svg{width:12px;height:12px}.action-badge.manual_task{color:var(--primary-light);background:#002e5d26}.action-badge.text_message{color:var(--info);background:#1976d226}.action-badge.email_notification{color:var(--accent);background:#d4a84326}.action-badge.visit_scheduling{color:var(--success);background:#2e7d3226}.action-badge.phone_call{color:var(--warning);background:#ef8c2226}.bento-grid{gap:var(--space-lg);grid-template-columns:repeat(4,1fr);display:grid}.bento-grid .span-2{grid-column:span 2}.bento-grid .span-3{grid-column:span 3}.bento-grid .span-4{grid-column:span 4}.search-bar{align-items:center;gap:var(--space-sm);background:var(--bg-input);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:0 var(--space-md);transition:border-color var(--transition-fast);display:flex}.search-bar:focus-within{border-color:var(--primary)}.search-bar svg{color:var(--text-muted);flex-shrink:0;width:16px;height:16px}.search-bar input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;padding:.55rem 0;font-family:Inter,sans-serif;font-size:.9rem}.search-bar input::placeholder{color:var(--text-muted)}.filter-bar{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.filter-chip{cursor:pointer;transition:all var(--transition-fast);border:1px solid var(--glass-border);color:var(--text-secondary);background:0 0;border-radius:100px;padding:.3rem .75rem;font-size:.8rem;font-weight:500}.filter-chip:hover{border-color:var(--border-hover);background:var(--primary-subtle)}.filter-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.workflow-timeline{padding-left:28px;position:relative}.workflow-timeline:before{content:"";background:var(--glass-border);width:2px;position:absolute;top:0;bottom:0;left:11px}.timeline-step{padding:var(--space-md) 0;position:relative}.timeline-dot{left:-28px;top:var(--space-md);z-index:1;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex;position:absolute}.timeline-dot svg{width:12px;height:12px}.timeline-dot.completed{background:var(--success);color:#fff}.timeline-dot.in_progress{background:var(--warning);color:#fff;animation:2s infinite pulse}.timeline-dot.pending{background:var(--bg-surface);border:2px solid var(--glass-border);color:var(--text-muted)}.timeline-dot.skipped{background:var(--bg-surface);border:2px solid var(--text-muted);color:var(--text-muted)}.timeline-content{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-md);transition:border-color var(--transition-fast)}.timeline-content:hover{border-color:var(--border-hover)}.timeline-header{justify-content:space-between;align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.timeline-title{font-size:.9rem;font-weight:600}.timeline-desc{color:var(--text-secondary);margin-top:var(--space-xs);font-size:.85rem}.timeline-meta{align-items:center;gap:var(--space-md);margin-top:var(--space-sm);color:var(--text-muted);flex-wrap:wrap;font-size:.78rem;display:flex}.timeline-title-row{flex-wrap:wrap;align-items:center;gap:8px;min-width:0;display:flex}.timeline-actions{gap:var(--space-sm);flex-wrap:wrap;align-items:center;display:flex}.assignment-pill{color:var(--warning);background:#ef8c2226;border-radius:100px;align-items:center;gap:4px;padding:.15rem .5rem;font-size:.72rem;font-weight:600;display:inline-flex}.menu-anchor{position:relative}.dropdown-menu{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-md);z-index:50;min-width:200px;max-width:min(280px,100vw - 2rem);position:absolute;top:calc(100% + 4px);right:0;overflow:hidden;box-shadow:0 8px 24px #00000026}.dropdown-menu-item{text-align:left;cursor:pointer;width:100%;color:var(--text-primary);background:0 0;border:none;padding:.5rem .75rem;font-size:.85rem;display:block}.dropdown-menu-item:hover{background:var(--primary-subtle)}.empty-state{text-align:center;padding:var(--space-2xl);color:var(--text-muted)}.empty-state svg{width:48px;height:48px;margin-bottom:var(--space-md);opacity:.4}.empty-state h3{color:var(--text-secondary);margin-bottom:var(--space-sm)}.empty-state p{max-width:360px;margin:0 auto;font-size:.9rem}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;padding:var(--space-lg);background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border:1px solid var(--glass-border);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:85vh;animation:.3s slideUp;overflow-y:auto;box-shadow:0 24px 80px #00000080}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;display:flex}.modal-header h2{font-size:1.15rem}.modal-body{padding:var(--space-lg)}.modal-footer{justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--glass-border);display:flex}.login-page{min-height:100vh;padding:var(--space-lg);background:linear-gradient(160deg,#002e5d 0%,#1a5276 40%,#f5f5f0 40.1%);justify-content:center;align-items:center;display:flex}.login-card{border:1px solid var(--glass-border);border-radius:var(--radius-xl);width:100%;max-width:400px;padding:var(--space-2xl);background:#fff;box-shadow:0 12px 48px #002e5d26}.login-logo{margin-bottom:var(--space-xl);flex-direction:column;align-items:center;display:flex}.login-logo-icon{background:linear-gradient(135deg, var(--primary), var(--accent));border-radius:var(--radius-lg);width:56px;height:56px;margin-bottom:var(--space-md);justify-content:center;align-items:center;display:flex;box-shadow:0 4px 20px #002e5d66}.login-logo-icon svg{color:#fff;width:28px;height:28px}.login-logo h1{text-align:center;font-size:1.4rem}.login-logo p{color:var(--text-muted);margin-top:var(--space-xs);font-size:.85rem}.login-error{background:var(--danger-light);color:var(--danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md);font-size:.85rem}.activity-feed{flex-direction:column;gap:2px;max-height:340px;display:flex;overflow-y:auto}.activity-item{align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm) 0;border-bottom:1px solid var(--border-subtle);display:flex}.activity-item:last-child{border-bottom:none}.activity-dot{background:var(--primary);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.activity-text{color:var(--text-secondary);font-size:.83rem;line-height:1.4}.activity-text strong{color:var(--text-primary);font-weight:600}.activity-time{color:var(--text-muted);margin-top:2px;font-size:.72rem}.step-list{gap:var(--space-md);flex-direction:column;display:flex}.step-card{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-md);align-items:flex-start;gap:var(--space-md);transition:all var(--transition-fast);display:flex}.step-card:hover{border-color:var(--border-hover)}.step-card.dragging{opacity:.4;border-style:dashed}.step-card.drag-over{border-color:var(--primary);background:var(--primary-subtle);border-width:2px;box-shadow:0 0 0 3px #002e5d26}.drag-handle{color:var(--text-muted);cursor:grab;border-radius:var(--radius-sm);transition:color var(--transition-fast), background var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;padding:2px;display:flex}.drag-handle:hover{color:var(--text-primary);background:var(--primary-subtle)}.drag-handle:active{cursor:grabbing}.step-number{border-radius:var(--radius-full);background:var(--primary-subtle);width:28px;height:28px;color:var(--primary-light);flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.step-content{flex:1}.step-actions{gap:var(--space-xs);display:flex}.step-header{align-items:center;gap:var(--space-sm);cursor:pointer;width:100%;display:flex}.step-summary{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.9rem;font-weight:500;overflow:hidden}.step-details{margin-top:var(--space-md);width:100%;padding-left:36px}.assignment-toggle{gap:var(--space-sm);margin-bottom:var(--space-sm);flex-wrap:wrap;display:flex}.condition-options{gap:var(--space-sm);flex-wrap:wrap;display:flex}.condition-option{min-width:140px}.condition-badge{background:var(--warning-light);color:#e65100;white-space:nowrap;border-radius:100px;flex-shrink:0;align-items:center;gap:4px;padding:.15rem .5rem;font-size:.68rem;font-weight:600;display:inline-flex}.condition-builder{margin-top:var(--space-md);padding:var(--space-md);border:1px solid var(--glass-border);border-radius:var(--radius-md);background:var(--bg-input)}.condition-classes{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--glass-border)}.checkbox-group{align-items:center;gap:var(--space-sm);cursor:pointer;display:flex}.checkbox-group input[type=checkbox]{appearance:none;border:2px solid var(--glass-border);background:var(--bg-input);cursor:pointer;width:18px;height:18px;transition:all var(--transition-fast);border-radius:4px;justify-content:center;align-items:center;display:flex}.checkbox-group input[type=checkbox]:checked{background:var(--primary);border-color:var(--primary)}.checkbox-group input[type=checkbox]:checked:after{content:"✓";color:#fff;font-size:11px;font-weight:700}.checkbox-label{color:var(--text-secondary);font-size:.875rem}.leaderboard{gap:var(--space-xs);flex-direction:column;display:flex}.leaderboard-item{align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;display:flex}.leaderboard-rank{border-radius:var(--radius-full);background:var(--primary-subtle);width:24px;height:24px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.leaderboard-name{flex:1;font-size:.88rem;font-weight:500}.leaderboard-count{color:var(--accent);font-size:.85rem;font-weight:700}.toast-container{top:var(--space-lg);right:var(--space-lg);z-index:2000;gap:var(--space-sm);flex-direction:column;display:flex;position:fixed}.toast{background:var(--bg-surface);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-md);align-items:center;gap:var(--space-sm);min-width:280px;animation:.3s slideIn;display:flex;box-shadow:0 8px 24px #0006}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}.loading-spinner{padding:var(--space-2xl);justify-content:center;align-items:center;display:flex}.spinner{border:3px solid var(--glass-border);border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.mobile-menu-toggle{top:var(--space-md);left:var(--space-md);z-index:200;background:var(--bg-surface);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-sm);color:var(--text-primary);cursor:pointer;display:none;position:fixed}.sidebar-overlay{z-index:99;background:#00000080;display:none;position:fixed;inset:0}.role-pill{text-transform:capitalize;border-radius:100px;padding:.15rem .6rem;font-size:.72rem;font-weight:600;display:inline-block}.role-pill.admin{color:#ef5350;background:#d32f2f26}.role-pill.mission_leader{color:var(--primary-light);background:#002e5d26}.role-pill.ward_missionary{color:#66bb6a;background:#2e7d3226}.tab-bar{gap:var(--space-xs);border-bottom:2px solid var(--glass-border);padding-bottom:0;display:flex}.tab-btn{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-2px;padding:.6rem 1.1rem;font-size:.88rem;font-weight:500;display:flex}.tab-btn:hover{color:var(--text-secondary)}.tab-btn.active{color:var(--primary-light);border-bottom-color:var(--primary)}.tab-btn svg{width:15px;height:15px}.tab-badge{background:var(--primary);color:#fff;border-radius:100px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:.68rem;font-weight:700;display:inline-flex}.class-group{border:1px solid var(--glass-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast);overflow:hidden}.class-group:hover{border-color:var(--border-hover)}.class-header{padding:var(--space-md) var(--space-lg);background:var(--bg-card);justify-content:space-between;align-items:center;display:flex}.class-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.class-label{font-size:.92rem;font-weight:600}.class-counter{background:var(--bg-input);border:1px solid var(--glass-border);border-radius:var(--radius-md);align-items:center;gap:2px;display:flex;overflow:hidden}.counter-btn{width:32px;height:32px;color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;font-size:1.1rem;font-weight:600;display:flex}.counter-btn:hover:not(:disabled){background:var(--primary-subtle)}.counter-btn:disabled{opacity:.3;cursor:not-allowed}.counter-value{text-align:center;font-variant-numeric:tabular-nums;width:28px;font-size:.92rem;font-weight:700}.class-members{gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--bg-input);border-top:1px solid var(--glass-border);flex-direction:column;animation:.25s slideDown;display:flex}.family-info-row{gap:var(--space-md);display:flex}.family-info-label{width:100px;color:var(--text-muted);flex-shrink:0;font-size:.85rem}.family-info-value{min-width:0;font-size:.9rem}.member-input-row{align-items:center;gap:var(--space-sm);animation:.2s fadeIn;display:flex}.member-number{border-radius:var(--radius-full);background:var(--primary-subtle);width:22px;height:22px;color:var(--primary-light);flex-shrink:0;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:flex}.member-input-row .form-input{flex:1}@keyframes slideDown{0%{opacity:0;max-height:0;padding-top:0;padding-bottom:0}to{opacity:1;max-height:600px;padding-top:var(--space-md);padding-bottom:var(--space-md)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{box-shadow:0 0 #ef8c2266}50%{box-shadow:0 0 0 8px #ef8c2200}}@media (width<=1024px){.bento-grid{grid-template-columns:repeat(2,1fr)}.bento-grid .span-3,.bento-grid .span-4{grid-column:span 2}}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.mobile-menu-toggle{display:flex}.sidebar-overlay.open{display:block}.main-content{padding:var(--space-md);margin-left:0;padding-top:60px}.bento-grid{grid-template-columns:1fr}.bento-grid .span-2,.bento-grid .span-3,.bento-grid .span-4{grid-column:span 1}.form-row{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.page-actions,.section-actions{width:100%}.page-actions .btn,.section-actions .btn{flex:auto;justify-content:center}.split-layout,.split-layout-wide{grid-template-columns:1fr}.sticky-panel{position:static;top:auto}.data-table{font-size:.85rem}.desktop-table-wrapper{display:none}.mobile-card-list{gap:var(--space-md);display:grid}.mobile-record-header{flex-direction:column;align-items:flex-start}.mobile-record-field{grid-template-columns:1fr;gap:.2rem}.workflow-timeline{padding-left:22px}.workflow-timeline:before{left:8px}.timeline-dot{left:-22px}.timeline-header{align-items:flex-start}.timeline-actions{flex-direction:column;align-items:stretch}.timeline-actions .menu-anchor{width:100%;margin-left:0!important}.timeline-actions .menu-anchor .btn,.timeline-actions>.btn,.timeline-actions>.checkbox-group{justify-content:center;width:100%}.dropdown-menu{min-width:min(100%,100vw - 3rem);left:0;right:auto}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{justify-content:center;width:100%}.tab-bar{padding-bottom:var(--space-xs);overflow-x:auto}.ribbon-header{flex-wrap:wrap;align-items:flex-start}.ribbon-template{flex-basis:100%}.step-header{flex-wrap:wrap;align-items:flex-start}.step-summary{white-space:normal;flex-basis:100%;order:10}.step-actions{justify-content:flex-end;width:100%}.step-details{padding-left:0}.condition-option{min-width:calc(50% - var(--space-sm))}.family-info-row{flex-direction:column;gap:.2rem}.family-info-label{width:auto}.modal{border-radius:var(--radius-lg);max-width:100%;max-height:100vh}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.ribbon-card{background:var(--bg-surface);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-md)}.ribbon-header{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);display:flex}.ribbon-family-name{color:var(--primary);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;padding:0;font-size:.95rem;font-weight:700;line-height:1;display:inline-flex}.ribbon-family-name:hover{color:var(--primary-dark);text-decoration:underline}.ribbon-template{color:var(--text-muted);flex:1;font-size:.78rem}.ribbon-pct{color:var(--success);font-size:.85rem;font-weight:700}.ribbon-progress-track{background:var(--bg-input);width:100%;height:6px;margin-bottom:var(--space-md);border-radius:100px;overflow:hidden}.ribbon-progress-fill{background:linear-gradient(90deg, var(--primary), var(--success));border-radius:100px;height:100%;transition:width .6s}.ribbon-steps{padding-bottom:var(--space-sm);align-items:flex-start;gap:0;display:flex;overflow-x:auto}.ribbon-step{flex-direction:column;flex-shrink:0;align-items:center;min-width:72px;display:flex;position:relative}.ribbon-node{z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.7rem;font-weight:700;transition:transform .2s,box-shadow .2s;display:flex;position:relative}.ribbon-node.completed{background:var(--success);color:#fff;box-shadow:0 2px 8px #2e7d3266}.ribbon-node.active{background:var(--accent);color:#fff;animation:2s infinite pulse-ring;box-shadow:0 0 0 4px #b78b2040}.ribbon-node.pending{background:var(--bg-input);color:var(--text-muted);border:2px solid var(--glass-border)}.ribbon-node.skipped{background:repeating-linear-gradient(45deg, var(--bg-input), var(--bg-input) 3px, var(--glass-border) 3px, var(--glass-border) 5px);color:var(--text-muted);font-size:.85rem}.ribbon-node:hover{z-index:2;transform:scale(1.15)}@keyframes pulse-ring{0%,to{box-shadow:0 0 0 4px #b78b2040}50%{box-shadow:0 0 0 8px #b78b201a}}.ribbon-connector{background:var(--glass-border);z-index:0;width:100%;height:3px;position:absolute;top:14px;right:50%}.ribbon-connector.completed{background:var(--success)}.ribbon-connector.skipped{background:repeating-linear-gradient(90deg, var(--glass-border) 0, var(--glass-border) 4px, transparent 4px, transparent 8px)}.ribbon-label{color:var(--text-secondary);text-align:center;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:80px;margin-top:6px;font-size:.65rem;line-height:1.2;display:-webkit-box;overflow:hidden}.ribbon-label.skipped{color:var(--text-muted);opacity:.6;text-decoration:line-through}.org-selector{flex-direction:column;gap:4px;display:flex}.org-selector-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:.7rem;font-weight:600}.org-selector-dropdown{background:var(--bg-input);width:100%;color:var(--text-primary);border:1px solid var(--glass-border);border-radius:var(--radius-sm);cursor:pointer;transition:border-color var(--transition-fast);outline:none;padding:6px 10px;font-size:.82rem}.org-selector-dropdown:hover{border-color:var(--border-hover)}.org-selector-dropdown:focus{border-color:var(--primary)}.org-badge-single{color:var(--text-secondary);background:var(--bg-input);border:1px solid var(--glass-border);border-radius:var(--radius-sm);align-items:center;gap:6px;padding:6px 10px;font-size:.8rem;font-weight:500;display:flex}.org-badge-dot{background:var(--success);border-radius:50%;flex-shrink:0;width:7px;height:7px}
