@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#fdfcf9;--bg-secondary:#f4f1e8;--bg-accent:#e9e4d1;--text-primary:#3d342d;--text-secondary:#6b5e53;--text-muted:#9c9187;--brand-primary:#8d9a5b;--brand-hover:#77834d;--brand-light:#8d9a5b1f;--brand-gradient:linear-gradient(135deg, #8d9a5b, #a5b17a);--surface-glass:#ffffffb3;--surface-border:#3d342d1a;--surface-shadow:0 4px 30px #3d342d0d;--danger:#c25e5e;--warning:#d4a017;--success:#8d9a5b;--br-lg:12px;--br-md:8px;--br-sm:6px;--transition:all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Outfit,sans-serif;overflow-x:hidden}.glass-panel{background:var(--surface-glass);-webkit-backdrop-filter:blur(12px);border:1px solid var(--surface-border);border-radius:var(--br-lg);box-shadow:var(--surface-shadow)}.text-gradient{background:var(--brand-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.btn-primary{background:var(--brand-primary);color:#fff;border-radius:var(--br-md);cursor:pointer;transition:var(--transition);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-family:Outfit,sans-serif;font-weight:500;display:flex}.btn-primary:hover{background:var(--brand-hover);transform:translateY(-2px);box-shadow:0 4px 12px #8d9a5b33}.btn-secondary{color:var(--text-primary);border:1px solid var(--surface-border);border-radius:var(--br-md);cursor:pointer;transition:var(--transition);background:0 0;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-family:Outfit,sans-serif;font-weight:500;display:flex}.btn-secondary:hover{background:var(--bg-secondary)}.app-container{width:100vw;height:100vh;display:flex;overflow:hidden}.main-content{background:var(--bg-primary);flex-direction:column;flex:1;display:flex;overflow-y:auto}.page-container{width:100%;max-width:1400px;margin:0 auto;padding:2rem}.page-header{margin-bottom:2rem}.page-title{margin-bottom:.5rem;font-size:2rem;font-weight:600}.page-subtitle{color:var(--text-secondary);font-size:1rem}.grid-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.input-group{flex-direction:column;gap:.5rem;margin-bottom:1rem;display:flex}.input-group label{color:var(--text-secondary);margin-bottom:.25rem;font-size:.9rem;font-weight:500}.input-field{color:var(--text-primary);transition:var(--transition);background:#f3f1e5;border:1px solid #d9d5bd;border-radius:6px;outline:none;padding:.75rem 1rem;font-family:Outfit,sans-serif}.input-field:focus{border-color:var(--brand-primary);background:#fff;box-shadow:0 0 0 3px #8d9a5b1a}.input-field::placeholder{color:#b0a695}.modal-overlay{-webkit-backdrop-filter:blur(2px);z-index:100;background:#3d342d66;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.2s fadeIn;display:flex;position:fixed;top:0;left:0}.modal-content{background:#eeeadd;border:1px solid #3d342d1a;border-radius:12px;width:90%;max-width:550px;padding:2.5rem;animation:.3s slideUp;box-shadow:0 10px 40px #3d342d26}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.modal-title{color:#4b3f35;font-size:1.5rem;font-weight:600}.close-btn{color:#9c9187;cursor:pointer;transition:var(--transition);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.close-btn:hover{color:var(--danger);transform:scale(1.1)}.form-group{flex-direction:column;margin-bottom:1.25rem;display:flex}.modal-actions{justify-content:flex-end;align-items:center;gap:1.5rem;margin-top:2rem;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.sidebar{border-right:1px solid var(--surface-border);z-index:10;background:var(--bg-secondary);border-radius:0;flex-direction:column;width:260px;height:100vh;padding:1.5rem;transition:width .3s cubic-bezier(.4,0,.2,1),padding .3s;display:flex;position:relative}.sidebar.collapsed{width:80px;padding:1.5rem .75rem}.collapse-toggle{background:var(--brand-primary);color:#fff;border:1px solid var(--surface-border);cursor:pointer;z-index:20;width:24px;height:24px;transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:1.5rem;right:-12px}.collapse-toggle:hover{background:var(--brand-hover);transform:scale(1.1)}.sidebar-brand{white-space:nowrap;align-items:center;gap:1rem;margin-bottom:3rem;padding-left:.5rem;display:flex;overflow:hidden}.collapsed .sidebar-brand{justify-content:center;padding-left:0}.brand-icon{color:var(--brand-primary);background:var(--brand-light);border-radius:var(--br-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.8rem;display:flex;box-shadow:0 4px 12px #8d9a5b26}.sidebar-brand h2{letter-spacing:.5px;font-size:1.25rem;font-weight:600;line-height:1.2}.sidebar-nav{flex-direction:column;flex:1;gap:.5rem;display:flex}.nav-item{color:var(--text-secondary);border-radius:var(--br-md);transition:var(--transition);white-space:nowrap;align-items:center;gap:1rem;padding:.85rem 1rem;font-weight:500;text-decoration:none;display:flex;position:relative;overflow:hidden}.collapsed .nav-item{justify-content:center;padding:.85rem}.nav-item:hover{background:var(--brand-light);color:var(--text-primary);transform:translate(4px)}.collapsed .nav-item:hover{transform:none}.nav-item.active{background:var(--brand-primary);color:#fff}.sidebar-footer{border-top:1px solid var(--surface-border);margin-top:auto;padding-top:1.5rem}.status-indicator{color:var(--text-muted);border-radius:var(--br-sm);background:#ffffff80;align-items:center;gap:.75rem;padding:.5rem 1rem;font-size:.85rem;display:flex}.status-dot{background-color:var(--success);width:8px;height:8px;box-shadow:0 0 8px var(--success);border-radius:50%;animation:2s infinite pulse}.brand-logo-img{object-fit:contain;border-radius:var(--br-md);background:#fff;width:44px;height:44px;padding:4px;box-shadow:0 4px 12px #3d342d14}.nav-divider{background:var(--surface-border);opacity:.5;height:1px;margin:.5rem 0}@keyframes pulse{0%{box-shadow:0 0 #8d9a5b66}70%{box-shadow:0 0 0 6px #8d9a5b00}to{box-shadow:0 0 #8d9a5b00}}.topbar{border-bottom:1px solid var(--surface-border);background:var(--bg-primary);z-index:5;border-radius:0;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0}.search-bar{background:var(--bg-secondary);border:1px solid var(--surface-border);border-radius:var(--br-md);width:350px;transition:var(--transition);align-items:center;padding:.5rem 1rem;display:flex}.search-bar:focus-within{border-color:var(--brand-primary);box-shadow:0 0 0 3px var(--brand-light);background:#fff}.search-icon{color:var(--text-muted);margin-right:.75rem}.search-input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%;font-family:Outfit,sans-serif}.search-input::placeholder{color:var(--text-muted)}.topbar-actions{align-items:center;gap:1.5rem;display:flex}.icon-btn{color:var(--text-secondary);cursor:pointer;width:40px;height:40px;transition:var(--transition);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.icon-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.notification-dot{background-color:var(--danger);border:2px solid var(--bg-primary);border-radius:50%;width:8px;height:8px;position:absolute;top:8px;right:10px}.user-profile{cursor:pointer;border-radius:var(--br-md);transition:var(--transition);border:1px solid #0000;align-items:center;gap:.75rem;padding:.25rem .5rem;display:flex}.user-profile:hover{background:var(--bg-secondary);border-color:var(--surface-border)}.avatar{background:var(--brand-gradient);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.user-info{flex-direction:column;display:flex}.user-name{color:var(--text-primary);font-size:.9rem;font-weight:500}.user-role{color:var(--text-muted);font-size:.75rem}.logout-btn{border-radius:var(--br-md);background:var(--bg-accent);color:var(--text-primary);border:1px solid var(--surface-border);cursor:pointer;transition:var(--transition);align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:500;display:flex}.logout-btn:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.dashboard-card{background:#fff;flex-direction:column;gap:1.5rem;padding:1.5rem;transition:transform .3s,box-shadow .3s;display:flex}.dashboard-card:hover{box-shadow:0 12px 40px var(--surface-border);transform:translateY(-5px)}.card-header{justify-content:space-between;align-items:flex-start;display:flex}.card-icon{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.card-trend{color:var(--success);background:var(--brand-light);border-radius:20px;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.85rem;font-weight:600;display:flex}.card-body h3{letter-spacing:-.5px;color:var(--text-primary);margin-bottom:.25rem;font-size:2rem;font-weight:700}.card-body p{color:var(--text-secondary);font-size:.95rem}.dashboard-content.dashboard-rearranged{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}@media (width<=1024px){.dashboard-content.dashboard-rearranged{grid-template-columns:1fr}}.section-title{border-bottom:1px solid var(--surface-border);color:var(--text-primary);margin-bottom:1.5rem;padding-bottom:1rem;font-size:1.2rem;font-weight:600}.recent-activity,.upcoming-classes{background:#fff;padding:1.5rem}.activity-list{flex-direction:column;gap:1rem;display:flex}.activity-item{border-radius:var(--br-md);background:var(--bg-primary);transition:var(--transition);align-items:center;gap:1rem;padding:.75rem;display:flex}.activity-item:hover{background:var(--bg-secondary)}.activity-avatar{background:var(--brand-gradient);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;font-weight:700;display:flex}.activity-details h4{color:var(--text-primary);margin-bottom:.15rem;font-size:.95rem}.activity-details p{color:var(--text-muted);font-size:.8rem}.activity-time{color:var(--text-secondary);margin-left:auto;font-size:.85rem;font-weight:500}.class-list{flex-direction:column;gap:1rem;display:flex}.class-item{border-radius:var(--br-md);border:1px solid var(--surface-border);background:var(--bg-primary);align-items:center;gap:1rem;padding:1rem;display:flex}.class-time{color:var(--brand-primary);min-width:65px;font-size:.9rem;font-weight:600}.class-info h4{color:var(--text-primary);margin-bottom:.25rem;font-size:.95rem}.class-info p{color:var(--text-muted);font-size:.8rem}.dashboard-card.highlight-blue{border-bottom:4px solid #3b82f6}.dashboard-card.highlight-green{border-bottom:4px solid #22c55e}.dashboard-card.highlight-purple{border-bottom:4px solid #a855f7}.status-dot{background:#22c55e;border-radius:50%;width:8px;height:8px;margin-left:auto;box-shadow:0 0 8px #22c55e66}.empty-msg{color:var(--text-muted);font-size:.9rem;font-style:italic}.trial-item{border-left:4px solid #22c55e!important}.trial-badge{color:#166534;text-transform:uppercase;background:#22c55e1a;border-radius:12px;margin-left:auto;padding:.25rem .6rem;font-size:.75rem;font-weight:600}.finance-section{margin-top:2rem}.finance-section-header{align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.finance-section-header h2{font-size:1.4rem;font-weight:600}.finance-section-header .header-icon{color:#10b981;background:linear-gradient(135deg,#10b98133,#3b82f633);border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.finance-summary-cards{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem;margin-bottom:1.75rem;display:grid}.finance-summary-card{flex-direction:column;gap:.75rem;padding:1.25rem;transition:transform .3s,box-shadow .3s;display:flex;position:relative;overflow:hidden}.finance-summary-card:before{content:"";border-radius:16px 16px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.finance-summary-card.revenue:before{background:linear-gradient(90deg,#10b981,#3b82f6)}.finance-summary-card.average:before{background:linear-gradient(90deg,#8b5cf6,#ec4899)}.finance-summary-card.subscriptions:before{background:linear-gradient(90deg,#f59e0b,#ef4444)}.finance-summary-card.growth:before{background:linear-gradient(90deg,#06b6d4,#3b82f6)}.finance-summary-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000059}.finance-card-icon{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.finance-card-value{letter-spacing:-.5px;font-size:1.75rem;font-weight:700;line-height:1}.finance-card-label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.finance-card-trend{align-items:center;gap:.3rem;margin-top:.25rem;font-size:.8rem;font-weight:600;display:flex}.finance-card-trend.positive{color:#10b981}.finance-card-trend.neutral{color:var(--text-muted)}.finance-tabs{background:#f4f1e8;border:1px solid #3d342d0d;border-radius:40px;gap:0;width:fit-content;margin-bottom:2rem;padding:.5rem;display:flex}.finance-tab{color:#7c7267;cursor:pointer;background:0 0;border:none;border-radius:30px;min-width:100px;padding:.6rem 1.6rem;font-family:Outfit,sans-serif;font-size:.95rem;font-weight:600;transition:all .2s}.finance-tab:hover{color:#3d342d}.finance-tab.active{color:#8d9a5b;background:#fff;box-shadow:0 4px 12px #3d342d14}.finance-charts{grid-template-columns:1.8fr 1fr;gap:1.5rem;display:grid}@media (width<=1024px){.finance-charts{grid-template-columns:1fr}}.chart-panel{padding:1.5rem}.chart-panel-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.chart-panel-header h3{font-size:1.1rem;font-weight:600}.chart-panel-header .chart-total{color:var(--text-secondary);font-size:.9rem;font-weight:500}.bar-chart-container{width:100%;position:relative}.bar-chart-svg{width:100%;height:260px;overflow:visible}.bar-chart-bar{cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1)}.bar-chart-bar:hover{filter:brightness(1.25)}.bar-chart-label{fill:var(--text-muted);font-family:Outfit,sans-serif;font-size:11px}.bar-chart-value{fill:var(--text-secondary);font-family:Outfit,sans-serif;font-size:10px;font-weight:600}.bar-chart-gridline{stroke:#ffffff0d;stroke-width:1px;stroke-dasharray:4}.bar-chart-axis-label{fill:var(--text-muted);font-family:Outfit,sans-serif;font-size:10px}.pie-chart-container{flex-direction:column;align-items:center;gap:1.25rem;display:flex}.pie-chart-svg{width:200px;height:200px}.pie-chart-slice{cursor:pointer;stroke:var(--bg-primary);stroke-width:2px;transition:all .3s}.pie-chart-slice:hover{filter:brightness(1.2);transform-origin:50%}.pie-legend{flex-direction:column;gap:.6rem;width:100%;display:flex}.pie-legend-item{border-radius:var(--br-sm);transition:var(--transition);background:#ffffff05;align-items:center;gap:.6rem;padding:.5rem .75rem;display:flex}.pie-legend-item:hover{background:#ffffff0f}.pie-legend-dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.pie-legend-label{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.82rem;overflow:hidden}.pie-legend-value{color:var(--text-primary);font-size:.82rem;font-weight:600}.pie-legend-pct{color:var(--text-muted);text-align:right;min-width:38px;font-size:.75rem}.finance-empty{text-align:center;color:var(--text-muted);flex-direction:column;grid-column:1/-1;justify-content:center;align-items:center;gap:.75rem;padding:3rem;display:flex}.finance-empty svg{opacity:.3}.finance-empty p{font-size:.95rem}@keyframes barGrow{0%{transform:scaleY(0)}to{transform:scaleY(1)}}.bar-animate{transform-origin:bottom;animation:.6s cubic-bezier(.4,0,.2,1) forwards barGrow}.chart-tooltip{background:var(--bg-secondary);border:1px solid var(--surface-border);border-radius:var(--br-sm);color:var(--text-primary);pointer-events:none;z-index:10;white-space:nowrap;padding:.5rem .75rem;font-size:.82rem;position:absolute;box-shadow:0 8px 24px #0006}.d-flex{display:flex}.justify-between{justify-content:space-between}.align-center{align-items:center}.header-actions{gap:1rem;display:flex}.attendance-filters-row{justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:1.5rem;padding:1.15rem 1.5rem;display:flex}.search-bar.inline{background:#fff;width:320px;margin-bottom:0}.filter-pill-container{background:#f4f1e8;border:1px solid #3d342d0d;border-radius:40px;gap:.25rem;padding:.5rem;display:flex}.filter-pill{color:#7c7267;cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:30px;padding:.6rem 1.4rem;font-size:.9rem;font-weight:600}.filter-pill:hover{color:#3d342d}.filter-pill.active{color:#8d9a5b;background:#fff;box-shadow:0 4px 12px #3d342d14}.date-picker-group{align-items:center;gap:.85rem;display:flex}.date-picker-group label{color:#9c9187;white-space:nowrap;font-size:.85rem;font-weight:500}.data-table-container{border-radius:var(--br-lg);border:1px solid var(--surface-border);background:#fff;overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;color:#7c7267;text-transform:uppercase;letter-spacing:.05em;background:#f9f8f3;border-bottom:2px solid #f4f1e8;padding:1.25rem 1.5rem;font-size:.8rem;font-weight:600}.data-table td{vertical-align:middle;color:var(--text-primary);border-bottom:1px solid #f4f1e8;padding:1.25rem 1.5rem;font-size:.95rem}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:#fdfcf9}.member-cell{align-items:center;gap:1rem;display:flex}.member-avatar-xs{background:var(--brand-gradient);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;font-weight:700;display:flex;overflow:hidden;box-shadow:0 4px 10px #8d9a5b26}.member-avatar-xs img{object-fit:cover;width:100%;height:100%}.member-name{color:#3d342d;font-weight:500}.time-stack{flex-direction:column;gap:.25rem;display:flex}.time-stack span:first-child{color:#4b3f35;font-size:.9rem;font-weight:600}.time-stack span:last-child{color:#9c9187;font-size:.8rem}.badge{border-radius:6px;padding:.35rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-member{color:#8d9a5b;background:#e8edd1}.badge-drop-in{color:#d4a017;background:#f9efd7}.badge-trial-class{color:#3b82f6;background:#e6f0f9}.status-present{color:#8d9a5b;align-items:center;gap:.4rem;font-size:.9rem;font-weight:600;display:inline-flex}.btn-remove{color:#c25e5e;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.4rem .8rem;font-size:.85rem;font-weight:600;transition:all .2s}.btn-remove:hover{background:#c25e5e1a;text-decoration:underline}.member-selection-grid{border:1px solid var(--surface-border);border-radius:var(--br-md);background:var(--bg-secondary);grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:1rem;max-height:300px;margin-top:.5rem;padding:.5rem;display:grid;overflow-y:auto}.member-check-card{border:1px solid var(--surface-border);border-radius:var(--br-md);cursor:pointer;transition:var(--transition);text-align:center;background:#fff;flex-direction:column;align-items:center;gap:.75rem;padding:1rem .75rem;display:flex}.member-check-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.member-check-card.selected{background:var(--brand-light);border-color:var(--brand-primary);box-shadow:0 0 0 2px var(--brand-primary)}.member-avatar-md{background:var(--brand-gradient);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.25rem;font-weight:700;display:flex;overflow:hidden;box-shadow:0 4px 10px #8d9a5b26}.member-avatar-md img{object-fit:cover;width:100%;height:100%}.member-name-tag{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;width:100%;font-size:.85rem;font-weight:600;display:block;overflow:hidden}.membership-controls{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.tabs{background:#f4f1e8;border:1px solid #3d342d0d;border-radius:40px;padding:.5rem;display:flex}.tab{color:#7c7267;cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:30px;padding:.6rem 1.4rem;font-family:inherit;font-size:.9rem;font-weight:600}.tab:hover{color:#3d342d}.tab.active{color:#8d9a5b;background:#fff;box-shadow:0 4px 12px #3d342d14}.members-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;display:grid}.member-card{background:#fff;flex-direction:column;padding:1.5rem;transition:transform .3s,box-shadow .3s;display:flex}.member-card:hover{box-shadow:0 10px 30px var(--surface-border);transform:translateY(-4px)}.member-avatar-lg{background:var(--brand-gradient);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.5rem;font-weight:700;display:flex;overflow:hidden;box-shadow:0 4px 12px #8d9a5b33}.member-photo-img{object-fit:cover;width:100%;height:100%}.photo-upload-section{background:var(--bg-secondary);border-radius:var(--br-md);border:1px dashed var(--surface-border);flex-direction:column;align-items:center;gap:1rem;margin-bottom:2rem;padding:1.5rem;display:flex}.photo-preview-lg{background:#fff;border:4px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;display:flex;overflow:hidden;box-shadow:0 4px 15px #3d342d1a}.photo-preview-lg img{object-fit:cover;width:100%;height:100%}.icon-btn-small{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:.25rem;display:flex}.icon-btn-small:hover{background:var(--bg-secondary);color:var(--text-primary);transform:scale(1.1)}.member-info{margin-top:1.25rem;margin-bottom:1.25rem}.member-info h3{color:var(--text-primary);margin-bottom:.25rem;font-size:1.25rem;font-weight:600}.email-text{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.85rem;display:flex}.plan-infobox{background:var(--bg-secondary);border-radius:var(--br-md);flex-direction:column;gap:.5rem;margin-bottom:1.5rem;padding:1rem;display:flex}.plan-name{color:var(--text-primary);font-weight:600}.status-badge{text-transform:capitalize;border-radius:20px;align-self:flex-start;padding:.25rem .65rem;font-size:.75rem;font-weight:600}.status-badge.active{color:var(--brand-primary);border:1px solid var(--brand-primary);background:#8d9a5b26}.status-badge.paused{color:var(--warning);border:1px solid var(--warning);background:#d4a0171a}.status-badge.expired{color:var(--danger);border:1px solid var(--danger);background:#c25e5e1a}.card-footer{border-top:1px solid var(--surface-border);margin-top:auto;padding-top:1.25rem}.expiry-info{flex-direction:column;display:flex}.expiry-info .label{color:var(--text-muted);margin-bottom:.1rem;font-size:.75rem}.expiry-info .value{color:var(--text-primary);font-size:.9rem;font-weight:500}.btn-link{color:var(--brand-primary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:4px;padding:.25rem .5rem;font-size:.9rem;font-weight:600}.btn-link:hover{background:var(--brand-light);text-decoration:underline}.trial-list-view{flex-direction:column;gap:1rem;display:flex}.trial-list-item{cursor:pointer;transition:var(--transition);border:1px solid var(--surface-border);justify-content:space-between;align-items:center;padding:1rem;display:flex}.trial-list-item:hover{border-color:var(--brand-primary);background:var(--brand-light);transform:translate(8px)}.trial-avatar{background:var(--bg-secondary);width:40px;height:40px;color:var(--brand-primary);border:1px solid var(--surface-border);border-radius:50%;justify-content:center;align-items:center;font-weight:700;display:flex}.trial-main h4{color:var(--text-primary);margin:0;font-size:1rem}.trial-date-badge{color:#8d9a5b;background:#f4f1e8;border-radius:20px;align-items:center;gap:.4rem;padding:.35rem .75rem;font-size:.8rem;font-weight:600;display:flex}.class-card{border:1px solid var(--surface-border);background:#fff;padding:1.5rem;transition:transform .2s,box-shadow .2s}.class-card:hover{box-shadow:0 12px 30px var(--surface-border);transform:translateY(-4px)}.icon-circle{border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.brand-bg{background:var(--brand-primary)}.border-bottom{border-bottom:1px solid var(--surface-border)}.pb-2{padding-bottom:.75rem}.mb-3{margin-bottom:1rem}.gap-2{gap:.75rem}.class-details p{align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.95rem;display:flex}.class-details strong{color:var(--text-primary);font-weight:500}.text-sm{font-size:.85rem}.progress-bg{background:var(--bg-secondary);border-radius:3px;width:100%;height:6px;overflow:hidden}.progress-fill{background:var(--brand-primary);border-radius:3px;height:100%;transition:width .3s}.days-indicator{gap:.35rem;display:flex}.day-pill{background:var(--bg-secondary);width:24px;height:24px;color:var(--text-muted);border:1px solid var(--surface-border);border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:flex}.day-pill.active{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary)}.days-selector{flex-wrap:wrap;gap:.5rem;display:flex}.day-btn{border-radius:var(--br-md);border:1px solid var(--surface-border);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:var(--transition);padding:.5rem .75rem;font-size:.85rem;font-weight:600}.day-btn.selected{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary);box-shadow:0 2px 8px #8d9a5b4d}.day-btn:hover:not(.selected){background:var(--surface-border);color:var(--text-primary)}.biometric-cloud-page{animation:.4s ease-out fadeIn}.sync-status-badge{color:var(--success);border:1px solid #10b98133;border-radius:30px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600;display:flex}.spin-slow{animation:3s linear infinite spin}.stat-card{border-radius:var(--br-md);align-items:center;gap:1.25rem;padding:1.5rem;display:flex}.stat-icon{background:#ffffff1a;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.highlight-blue .stat-icon{color:#3b82f6;background:#3b82f626}.highlight-green .stat-icon{color:#10b981;background:#10b98126}.highlight-purple .stat-icon{color:#a855f7;background:#a855f726}.stat-content h3{margin-bottom:.2rem;font-size:1.25rem;font-weight:700}.stat-content p{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.biometric-grid{grid-template-columns:400px 1fr;align-items:stretch;gap:2rem;display:grid}.sync-control-panel{flex-direction:column;padding:1.5rem;display:flex}.endpoint-info label,.auth-status label{color:var(--text-muted);text-transform:uppercase;margin-bottom:.4rem;font-size:.75rem;font-weight:600;display:block}.value-bar{border:1px solid var(--surface-border);background:#0003;border-radius:8px;padding:.75rem 1rem;font-family:monospace;font-size:.9rem}.status-item{color:var(--success);align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;display:flex}.btn-sync-large{background:var(--brand-gradient);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:1rem;width:100%;margin-top:1rem;padding:1.25rem;font-size:1.1rem;font-weight:700;transition:all .3s;display:flex;box-shadow:0 4px 15px #8d9a5b4d}.btn-sync-large:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #8d9a5b66}.btn-sync-large:active{transform:translateY(0)}.btn-sync-large.loading{opacity:.8;cursor:wait}.sync-feedback-msg{color:#10b981;background:#10b9811a;border:1px solid #10b98133;border-radius:8px;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem;font-size:.85rem;animation:.3s fadeIn;display:flex}.sync-activity-log{margin-top:auto;padding-top:2rem}.log-window{background:#000;border:1px solid #ffffff0d;border-radius:8px;height:120px;padding:1rem;font-family:Consolas,monospace;font-size:.75rem;overflow-y:auto}.log-line{color:#a3b8cc;border-left:2px solid var(--brand-primary);margin-bottom:.25rem;padding-left:.5rem}.attendance-preview-panel{flex-direction:column;padding:1.5rem;display:flex}.data-table-compact{flex:1;overflow-y:auto}.data-table-compact table{border-collapse:collapse;width:100%}.data-table-compact th{text-align:left;color:var(--text-muted);text-transform:uppercase;border-bottom:1px solid var(--surface-border);padding:1rem .5rem;font-size:.75rem}.data-table-compact td{border-bottom:1px solid #ffffff08;padding:1rem .5rem;font-size:.9rem}.emp-badge{background:var(--bg-secondary);color:var(--text-primary);border-radius:4px;padding:.25rem .5rem;font-weight:700}.sync-footer-info{color:var(--text-muted);align-items:center;gap:.75rem;padding:1rem 1.5rem;font-size:.85rem;display:flex}.spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (width<=1100px){.biometric-grid{grid-template-columns:1fr}}.login-wrapper{background:var(--bg-secondary);z-index:1000;justify-content:center;align-items:center;width:100vw;min-height:100vh;display:flex;position:absolute;top:0;left:0}.login-card{border-radius:var(--br-lg);border:1px solid var(--surface-border);background:#fff;width:100%;max-width:420px;padding:3rem 2.5rem;box-shadow:0 25px 50px -12px #3d342d1a}.text-center{text-align:center}.mx-auto{margin-left:auto;margin-right:auto}.mb-2{color:var(--text-primary);margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.pb-4{padding-bottom:1rem}.login-header{margin-bottom:2rem}.login-header p{color:var(--text-secondary)}.login-form{flex-direction:column;gap:1.25rem;display:flex}.form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-weight:500}.error-message{color:var(--danger);border-radius:var(--br-sm);text-align:center;background:#c25e5e1a;border:1px solid #c25e5e33;padding:.75rem 1rem;font-size:.85rem}.brand-icon{color:var(--brand-primary);margin-bottom:1rem;font-size:2.5rem}.settings-container{border:1px solid var(--surface-border);border-radius:var(--br-lg);background:#fff;max-width:900px;margin:0 auto;padding:3rem}.settings-grid{grid-template-columns:1fr 1fr;gap:3rem;margin-bottom:2rem;display:grid}@media (width<=768px){.settings-grid{grid-template-columns:1fr}}.settings-section h3{color:var(--text-primary);border-bottom:2px solid #a9abb5;margin-bottom:1.5rem;padding-bottom:.5rem;font-size:1.25rem;font-weight:600}.logo-upload-wrapper{border-radius:var(--br-md);background:#f3f1e5;border:1px dashed #d9d5bd;flex-direction:column;align-items:center;gap:1.5rem;padding:1.5rem;display:flex}.logo-preview{border-radius:var(--br-md);background:#fff;justify-content:center;align-items:center;width:120px;height:120px;display:flex;overflow:hidden;box-shadow:0 4px 12px #3d342d14}.logo-preview img{object-fit:contain;width:100%;height:100%}.logo-placeholder{color:#b0a695;flex-direction:column;align-items:center;gap:.5rem;display:flex}.logo-placeholder span{font-size:.8rem;font-weight:500}.upload-controls{flex-direction:column;align-items:center;gap:.5rem;display:flex}.help-text{color:var(--text-muted);font-size:.75rem}.input-with-icon{position:relative}.input-icon{color:#b0a695;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.input-field{padding-left:40px!important}.status-msg{border-radius:var(--br-md);text-align:center;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.9rem;font-weight:600}.status-msg.success{color:var(--brand-primary);border:1px solid var(--brand-primary);background:#8d9a5b1a}.settings-actions{border-top:1px solid var(--surface-border);justify-content:flex-end;padding-top:2rem;display:flex}.btn-sm{padding:.5rem 1rem;font-size:.85rem}.w-full{width:100%}.mb-6{margin-bottom:2rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}.integration-card{border:1px solid var(--surface-border);border-radius:var(--br-md);background:#f4f1e84d;padding:1.25rem}.int-header{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.int-header h4{color:var(--text-primary);margin:0;font-size:1rem;font-weight:600}.text-brand{color:var(--brand-primary)}.help-box{border-left:3px solid var(--brand-primary);background:#8d9a5b0f;border-radius:6px;padding:.85rem 1rem}.settings-section .form-group{margin-bottom:1.25rem}.text-xs{font-size:.78rem}.text-uppercase{text-transform:uppercase;letter-spacing:.05em}.text-muted{color:var(--text-muted)}.biometric-settings-section{border-top:1px solid var(--surface-border);margin-top:2.5rem;padding-top:2rem}.biometric-creds-grid{grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:1rem;display:grid}@media (width<=900px){.biometric-creds-grid{grid-template-columns:1fr}}.glass-panel-sm{border:1px solid var(--surface-border);border-radius:var(--br-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff9;padding:1.5rem}.cred-group-title{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:1.25rem;font-size:.95rem;font-weight:600;display:flex}.mb-4{margin-bottom:1.25rem}.mb-2{margin-bottom:.5rem}.mt-2{margin-top:.5rem}.input-password-wrap{align-items:center;display:flex;position:relative}.input-password-wrap .input-field{width:100%;padding-right:3rem}.eye-toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;align-items:center;padding:0;transition:color .2s;display:flex;position:absolute;right:.75rem}.eye-toggle:hover{color:var(--text-primary)}.auth-preview-box{background:#0b0f19e0;border:1px solid #ffffff0f;border-radius:10px;margin-top:1.25rem;padding:1rem 1.25rem}.auth-preview-label{color:#64748b;text-transform:uppercase;letter-spacing:.05em;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.75rem;display:flex}.copy-btn{color:#8d9a5b;cursor:pointer;background:#8d9a5b26;border:1px solid #8d9a5b4d;border-radius:20px;align-items:center;gap:.3rem;padding:.2rem .65rem;font-size:.75rem;font-weight:600;transition:all .2s;display:flex}.copy-btn:hover{background:#8d9a5b40}.auth-preview-value{color:#94a3b8;font-size:.8rem;line-height:1.9}.auth-key-label{color:#3b82f6;font-weight:600}.auth-b64{color:#10b981;word-break:break-all;font-size:.78rem}.api-url-preview{border:1px solid var(--surface-border);background:#f4f1e880;border-radius:10px;margin-top:1.25rem;padding:1rem 1.25rem}.api-url-code{color:#8d9a5b;word-break:break-all;margin-top:.5rem;font-size:.75rem;line-height:1.6;display:block}.empcode-options{gap:.75rem;margin-top:.5rem;margin-bottom:.5rem;display:flex}.empcode-btn{border:1.5px solid var(--surface-border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:.4rem;padding:.65rem;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.empcode-btn.active{border-color:var(--brand-primary);color:var(--brand-primary);background:#8d9a5b1a}code{background:#00000012;border-radius:4px;padding:.1rem .4rem;font-family:Consolas,Courier New,monospace;font-size:.85em}.leads-dashboard{animation:.4s ease-out fadeIn}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.stat-card{align-items:center;gap:1.25rem;padding:1.5rem;display:flex}.stat-icon{color:#fff;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-icon.today{background:linear-gradient(135deg,#ff6b6b,#ff8e53)}.stat-icon.week{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-icon.upcoming{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-info h3{margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.stat-info p{color:var(--text-secondary);font-size:.85rem;font-weight:500}.leads-controls{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem 1.5rem;display:flex}.filter-chip-container{background:#f4f1e8;border:1px solid #3d342d0d;border-radius:40px;gap:.25rem;padding:.4rem;display:flex}.filter-chip{color:#7c7267;cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:30px;padding:.5rem 1.25rem;font-size:.85rem;font-weight:600}.filter-chip.active{color:#8d9a5b;background:#fff;box-shadow:0 4px 12px #3d342d14}.lead-avatar{color:#8d9a5b;background:#f4f1e8;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;font-weight:700;display:flex}.lead-name-cell{align-items:center;gap:.75rem;font-weight:500;display:flex}.lead-contact{flex-direction:column;display:flex}.status-tag{border-radius:6px;padding:.35rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.stat-card{cursor:pointer;transition:var(--transition);align-items:center;gap:1.25rem;padding:1.5rem;display:flex}.stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #3d342d1f}.spinner-small{border:2px solid #0000001a;border-top:2px solid var(--primary);border-radius:50%;animation:1s linear infinite spin}.error-banner{background:#e11d480d;border:1px solid #e11d481a;border-radius:12px;animation:.3s ease-in-out fadeIn}.table-header-row{background:#f4f1e84d}.status-tag.trial-booked{color:#8d9a5b;background:#e8edd1}.status-tag.contacted{color:#3b82f6;background:#e6f0f9}.status-tag.pending{color:#d4a017;background:#f9efd7}.status-tag.closed{color:#e11d48;background:#fdecec}.btn-secondary:disabled{opacity:.7;cursor:not-allowed}.lead-detail-body{flex-direction:column;gap:.75rem;padding:1.5rem 0;display:flex}.lead-detail-row{align-items:flex-start;gap:.85rem;padding:.65rem .75rem;display:flex}.lead-detail-row>div{flex-direction:column;gap:.15rem;display:flex}.detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:500}.detail-value{color:var(--text-primary);font-size:.95rem;font-weight:500}
