:root{--color-primary-50: #F8F9FA;--color-primary-100: #E9ECEF;--color-primary-200: #DEE2E6;--color-primary-300: #CED4DA;--color-primary-400: #ADB5BD;--color-primary-500: #6C757D;--color-primary-600: #495057;--color-primary-700: #343A40;--color-primary-800: #2B3035;--color-primary-900: #1A1D21;--color-secondary-50: #F0F7F4;--color-secondary-100: #D4EBE1;--color-secondary-200: #B8DFCE;--color-secondary-300: #9CD3BB;--color-secondary-400: #7FC6A8;--color-secondary-500: #5FA888;--color-secondary-600: #4A8A6F;--color-secondary-700: #396C56;--color-secondary-800: #2A4E3E;--color-secondary-900: #1C3127;--color-neutral-0: #FFFFFF;--color-neutral-50: #FAFAF9;--color-neutral-100: #F5F4F1;--color-neutral-200: #E8E6E1;--color-neutral-300: #D3D0C9;--color-neutral-400: #B8B4AB;--color-neutral-500: #9C988D;--color-neutral-600: #7A7669;--color-neutral-700: #5C5850;--color-neutral-800: #3E3C36;--color-neutral-900: #28261F;--color-accent-50: #FDF8F3;--color-accent-100: #FAEDDD;--color-accent-300: #E8B87D;--color-accent-400: #D99C52;--color-accent-500: #B8813D;--color-success: #10B981;--color-success-bg: #ECFDF5;--color-success-border: #A7F3D0;--color-warning: #F59E0B;--color-warning-bg: #FFFBEB;--color-warning-border: #FDE68A;--color-error: #EF4444;--color-error-bg: #FEF2F2;--color-error-border: #FECACA;--color-info: #3B82F6;--color-info-bg: #EFF6FF;--color-bg: var(--color-neutral-50);--color-surface: #FFFFFF;--color-border: var(--color-neutral-200);--color-border-focus: var(--color-secondary-500);--color-text: var(--color-primary-900);--color-text-muted: var(--color-neutral-600);--color-text-subtle: var(--color-neutral-400);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--spacing-4xl: 5rem;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, "Courier New", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-md: 1.0625rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-base: 1.5;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 260px;--topbar-height: 60px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;font-family:var(--font-sans);font-size:var(--font-size-base);line-height:var(--line-height-base);color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;height:100%}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input,select,textarea{font-family:inherit;font-size:inherit}img,svg{display:block}ul,ol{list-style:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-weight:var(--font-weight-medium);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:.5rem 1rem;font-size:var(--font-size-sm);min-height:34px}.btn{padding:.625rem 1.25rem;font-size:var(--font-size-sm);min-height:38px}.btn-lg{padding:.75rem 1.75rem;font-size:var(--font-size-base);min-height:44px}.btn-primary{background-color:var(--color-primary-800);color:#fff;font-weight:var(--font-weight-semibold);box-shadow:0 1px 2px #0000001a}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-900);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background-color:var(--color-surface);color:var(--color-primary-700);border:1.5px solid var(--color-neutral-300)}.btn-secondary:hover:not(:disabled){background-color:var(--color-neutral-100);border-color:var(--color-neutral-400)}.btn-teal{background-color:var(--color-secondary-600);color:#fff;font-weight:var(--font-weight-semibold)}.btn-teal:hover:not(:disabled){background-color:var(--color-secondary-700)}.btn-ghost{background-color:transparent;color:var(--color-neutral-700);border:1px solid transparent}.btn-ghost:hover:not(:disabled){background-color:var(--color-neutral-100);color:var(--color-neutral-900);border-color:var(--color-neutral-300)}.btn-danger{background-color:var(--color-error-bg);color:#b91c1c;border:1px solid var(--color-error-border)}.btn-danger:hover:not(:disabled){background-color:#fee2e2}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-900);letter-spacing:.01em}.form-input{width:100%;padding:.625rem var(--spacing-md);border:1px solid var(--color-neutral-300);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-size:var(--font-size-base);font-family:var(--font-sans);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:hover:not(:disabled){border-color:var(--color-neutral-400)}.form-input:focus{border-color:var(--color-secondary-500);box-shadow:0 0 0 3px #5fa88826}.form-input::placeholder{color:var(--color-neutral-500)}.form-input:disabled{background:var(--color-neutral-100);cursor:not-allowed;opacity:.8}.form-textarea{padding:var(--spacing-sm) var(--spacing-md);resize:vertical;min-height:80px;height:auto}.form-select{-webkit-appearance:none;-moz-appearance:none;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='%237A7669' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-md) center;padding-right:2.5rem}.card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-neutral-200);transition:all var(--transition)}.card-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-neutral-200);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);font-weight:var(--font-weight-semibold);font-size:var(--font-size-lg);color:var(--color-primary-800)}.card-body{padding:var(--spacing-lg)}.card-hover:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--color-secondary-300)}.badge{display:inline-flex;align-items:center;gap:3px;padding:.2rem .6rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);white-space:nowrap;text-transform:uppercase;letter-spacing:.03em}.badge-green{background:#d1fae5;color:#065f46}.badge-yellow{background:#fef3c7;color:#92400e}.badge-red{background:#fee2e2;color:#991b1b}.badge-blue{background:#dbeafe;color:#1e40af}.badge-teal{background:var(--color-secondary-100);color:var(--color-secondary-800)}.badge-gray{background:var(--color-neutral-200);color:var(--color-neutral-700)}.table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--color-neutral-200)}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.table thead{background-color:var(--color-neutral-100)}.table th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-neutral-700);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-neutral-200);white-space:nowrap}.table td{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-neutral-200);vertical-align:middle}.table tbody tr:last-child td{border-bottom:none}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background-color:var(--color-neutral-50)}.table-clickable tbody tr{cursor:pointer}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--color-neutral-200);flex-wrap:wrap;gap:var(--spacing-md)}.page-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-primary-900)}.page-subtitle{font-size:var(--font-size-sm);color:var(--color-neutral-600);margin-top:2px}.page-content-area{animation:fade-in .3s ease-in}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl) var(--spacing-xl);gap:var(--spacing-md);color:var(--color-neutral-600);text-align:center}.empty-state-icon{color:var(--color-neutral-400);margin-bottom:var(--spacing-sm)}.empty-state-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary-800)}.empty-state-desc{font-size:var(--font-size-sm);max-width:320px;color:var(--color-neutral-600)}.spinner{width:1.25rem;height:1.25rem;border:2px solid var(--color-neutral-300);border-top-color:var(--color-secondary-500);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.spinner-lg{width:2.5rem;height:2.5rem;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{display:flex;align-items:center;justify-content:center;padding:var(--spacing-3xl)}.alert{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);border-left:4px solid transparent}.alert-error{background:var(--color-error-bg);color:#991b1b;border-left-color:var(--color-error);animation:shake .3s ease}.alert-success{background:var(--color-success-bg);color:#065f46;border-left-color:var(--color-success)}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:50;padding:var(--spacing-lg);animation:fade-backdrop .15s ease}@keyframes fade-backdrop{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:modal-slide-up .25s cubic-bezier(.16,1,.3,1)}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-neutral-200);flex-shrink:0}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary-800)}.modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:var(--spacing-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-neutral-200);flex-shrink:0}.tabs{display:flex;border-bottom:2px solid var(--color-neutral-200);margin-bottom:var(--spacing-lg);gap:0}.tab{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-neutral-600);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color var(--transition-fast),border-color var(--transition-fast);cursor:pointer;background:none;border-top:none;border-left:none;border-right:none}.tab:hover{color:var(--color-primary-800)}.tab.active{color:var(--color-secondary-700);border-bottom-color:var(--color-secondary-600);font-weight:var(--font-weight-semibold)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.stat-card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-neutral-200);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:all var(--transition)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-neutral-600);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-xs)}.stat-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-primary-900);line-height:var(--line-height-tight)}.stat-sub{font-size:var(--font-size-xs);color:var(--color-neutral-600);margin-top:var(--spacing-xs)}.search-bar{position:relative;flex:1;min-width:200px;max-width:360px}.search-bar .search-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--color-neutral-500);pointer-events:none}.search-bar .form-input{padding-left:2.25rem}.delete-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:50;padding:var(--spacing-lg)}.delete-confirm-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--spacing-xl);max-width:400px;width:100%;box-shadow:var(--shadow-xl);text-align:center}.delete-confirm-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary-900);margin-bottom:var(--spacing-sm)}.delete-confirm-desc{font-size:var(--font-size-sm);color:var(--color-neutral-600);margin-bottom:var(--spacing-xl);line-height:var(--line-height-base)}.delete-confirm-actions{display:flex;gap:var(--spacing-sm);justify-content:center}.toggle-row{display:flex;gap:var(--spacing-sm)}.toggle-btn{display:flex;align-items:center;gap:6px;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-neutral-300);border-radius:var(--radius-md);background:transparent;font-size:var(--font-size-sm);cursor:pointer;color:var(--color-neutral-600);transition:all var(--transition)}.toggle-btn:hover{border-color:var(--color-secondary-400);color:var(--color-secondary-700)}.toggle-btn.active{background:var(--color-secondary-600);border-color:var(--color-secondary-600);color:#fff}.selected-participant{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-secondary-50);border:1px solid var(--color-secondary-200);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-secondary-800)}@media(max-width:480px){.form-row-2{grid-template-columns:1fr}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-neutral-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-neutral-400)}.app-layout{display:flex;min-height:100vh;background:var(--color-neutral-50)}.app-header{position:fixed;top:0;left:0;right:0;height:var(--topbar-height);background-color:var(--color-primary-900);color:#fff;display:flex;align-items:center;padding:0 var(--spacing-xl);box-shadow:var(--shadow-md);z-index:40;gap:var(--spacing-md)}.app-header-brand{display:flex;align-items:center;gap:12px;flex-shrink:0;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app-header-logo{display:inline-block;height:32px;width:auto;max-width:110px;vertical-align:middle;object-fit:contain}.app-header-title-wrap{display:flex;flex-direction:column;justify-content:center;line-height:1.15;gap:2px}.app-header-wordmark{font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1.375rem;font-weight:700;letter-spacing:-.03em;color:#fff;margin:0}.app-header-product{font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.6875rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:#ffffffbf}.app-header-divider{width:1px;height:24px;background:#fff3;margin:0 var(--spacing-sm)}.app-header-spacer{flex:1}.app-header-user{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:#ffffffd9}.app-header-avatar{width:30px;height:30px;background:var(--color-secondary-600);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:#fff;flex-shrink:0}.app-header-logout{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:#ffffffbf;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);background:none;border:none}.app-header-logout:hover{background:#ffffff1a;color:#fff}.app-header-toggle{display:none;align-items:center;justify-content:center;padding:var(--spacing-xs);border-radius:var(--radius-md);color:#ffffffbf;background:none;border:none;cursor:pointer;transition:background var(--transition-fast)}.app-header-toggle:hover{background:#ffffff1a}.sidebar{width:var(--sidebar-width);background-color:var(--color-neutral-50);border-right:1px solid var(--color-neutral-200);position:fixed;top:var(--topbar-height);left:0;bottom:0;z-index:30;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-lg);transition:width var(--transition-slow),padding var(--transition-slow),opacity .25s ease,transform var(--transition-slow);display:flex;flex-direction:column;gap:var(--spacing-xs)}.sidebar-section-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-neutral-500);text-transform:uppercase;letter-spacing:.08em;padding:var(--spacing-sm) var(--spacing-md);margin-top:var(--spacing-sm)}.sidebar-section-label:first-child{margin-top:0}.sidebar-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-neutral-700);transition:all var(--transition-fast);text-decoration:none;white-space:nowrap;overflow:hidden}.sidebar-link:hover{background-color:#fffc;color:var(--color-primary-800);transform:translate(2px)}.sidebar-link.active{background-color:#fff;color:var(--color-primary-800);font-weight:var(--font-weight-semibold);box-shadow:0 1px 2px #0000000a;border-left:3px solid var(--color-secondary-600);padding-left:calc(var(--spacing-md) - 3px)}.sidebar-link-icon{flex-shrink:0}.sidebar-coming-soon{margin-left:auto;font-size:.65rem;font-weight:var(--font-weight-medium);color:var(--color-neutral-400);background:var(--color-neutral-100);border-radius:var(--radius-full);padding:1px 6px;text-transform:uppercase;letter-spacing:.04em}.main-content{flex:1;margin-left:var(--sidebar-width);margin-top:var(--topbar-height);min-height:calc(100vh - var(--topbar-height));min-width:0;display:flex;flex-direction:column}.page-content{flex:1;padding:var(--spacing-lg);max-width:1600px;width:100%;margin:0 auto}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:25;top:var(--topbar-height)}@media(max-width:768px){.sidebar{transform:translate(-100%);width:var(--sidebar-width)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.main-content{margin-left:0}.app-header-toggle{display:flex}.app-header-user-name{display:none}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-800) 0%,var(--color-primary-900) 50%,var(--color-secondary-900) 100%);padding:var(--spacing-lg)}.login-container{width:100%;max-width:420px;animation:login-slide-up .4s cubic-bezier(.16,1,.3,1)}@keyframes login-slide-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.login-card{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-xl);border:1px solid var(--color-neutral-200)}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-logo-wrap{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;background:var(--color-secondary-600);border-radius:var(--radius-lg);color:#fff;margin:0 auto var(--spacing-md)}.login-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary-900);margin-bottom:var(--spacing-xs);background:linear-gradient(135deg,var(--color-primary-800),var(--color-secondary-700));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.login-subtitle{font-size:var(--font-size-sm);color:var(--color-neutral-600);font-weight:var(--font-weight-medium)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.login-submit{width:100%;justify-content:center;background-color:var(--color-primary-800);color:#fff;font-weight:var(--font-weight-semibold);min-height:44px;font-size:var(--font-size-base);border-radius:var(--radius-md);padding:.75rem;transition:all var(--transition)}.login-submit:hover:not(:disabled){background-color:var(--color-primary-900);box-shadow:var(--shadow-md);transform:translateY(-1px)}.login-error{padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-error-bg);color:#991b1b;border-radius:var(--radius-md);font-size:var(--font-size-sm);text-align:center;border-left:4px solid var(--color-error);animation:shake .3s ease}.business-list{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.business-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border:1.5px solid var(--color-neutral-200);border-radius:var(--radius-md);cursor:pointer;background:var(--color-surface);transition:all var(--transition-fast);text-align:left;width:100%}.business-option:hover{border-color:var(--color-secondary-400);background:var(--color-secondary-50);transform:translate(2px)}.business-option-icon{width:36px;height:36px;background:var(--color-secondary-100);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-secondary-700);flex-shrink:0}.business-option-name{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-primary-800)}.business-option-slug{font-size:var(--font-size-xs);color:var(--color-neutral-500)}.login-back{margin-top:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-neutral-600);text-align:center}.login-back button{color:var(--color-secondary-700);font-weight:var(--font-weight-medium);background:none;border:none;cursor:pointer;padding:0;text-decoration:underline;text-decoration-style:dotted}.login-back button:hover{color:var(--color-secondary-600)}.dashboard-welcome{margin-bottom:var(--spacing-xl)}.dashboard-welcome-greeting{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-primary-900);letter-spacing:-.02em;line-height:var(--line-height-tight)}.dashboard-welcome-date{font-size:var(--font-size-sm);color:var(--color-neutral-600);margin-top:var(--spacing-xs)}.dashboard-section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary-800);margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.quick-action-card{display:flex;flex-direction:column;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-surface);border:1px solid var(--color-neutral-200);border-radius:var(--radius-lg);text-decoration:none;color:inherit;transition:all var(--transition);cursor:pointer;box-shadow:var(--shadow-sm);text-align:left}.quick-action-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--color-secondary-300)}.quick-action-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.quick-action-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary-800)}.quick-action-desc{font-size:var(--font-size-xs);color:var(--color-neutral-600)}.today-sessions-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.today-session-card{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-surface);border:1px solid var(--color-neutral-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition);text-decoration:none;color:inherit}.today-session-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-secondary-300);transform:translate(2px)}.today-session-time{background:var(--color-secondary-50);border:1px solid var(--color-secondary-200);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);text-align:center;min-width:72px;flex-shrink:0}.today-session-time-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-secondary-700);line-height:var(--line-height-tight)}.today-session-time-label{font-size:var(--font-size-xs);color:var(--color-secondary-500);text-transform:uppercase;letter-spacing:.05em}.today-session-info{flex:1;min-width:0}.today-session-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-primary-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.today-session-meta{font-size:var(--font-size-sm);color:var(--color-neutral-600);margin-top:2px;display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.today-session-actions{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.capacity-bar-wrapper{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.capacity-bar-track{flex:1;height:5px;background:var(--color-neutral-200);border-radius:var(--radius-full);overflow:hidden;min-width:60px}.capacity-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .3s ease}.capacity-bar-fill.low{background:var(--color-success)}.capacity-bar-fill.mid{background:var(--color-warning)}.capacity-bar-fill.full{background:var(--color-error)}.capacity-label{font-size:var(--font-size-xs);color:var(--color-neutral-600);white-space:nowrap}.class-card{background:var(--color-surface);border:1px solid var(--color-neutral-200);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--spacing-md);transition:all var(--transition);cursor:pointer;text-decoration:none;color:inherit}.class-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--color-secondary-300)}.class-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-sm)}.class-card-icon{width:40px;height:40px;background:var(--color-secondary-50);border:1px solid var(--color-secondary-200);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-secondary-700);flex-shrink:0}.class-card-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary-800);line-height:var(--line-height-tight);flex:1;display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.class-card-desc{font-size:var(--font-size-sm);color:var(--color-neutral-600);line-height:var(--line-height-base);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.class-card-age{display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-secondary-700);background:var(--color-secondary-50);border:1px solid var(--color-secondary-200);border-radius:var(--radius-full, 999px);padding:2px 10px;align-self:flex-start}.class-card-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-neutral-600);align-items:center}.class-card-meta-item{display:flex;align-items:center;gap:4px}.class-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:var(--spacing-sm);border-top:1px solid var(--color-neutral-200);gap:var(--spacing-sm);margin-top:auto}.class-form-modal{max-width:600px!important}.cf-steps{display:flex;gap:0;margin-top:8px;flex-wrap:wrap;gap:4px}.cf-step{display:flex;align-items:center;gap:5px;padding:3px 12px 3px 10px;border:1px solid var(--color-neutral-300);border-radius:var(--radius-full, 999px);background:transparent;font-size:var(--font-size-xs);cursor:default;color:var(--color-neutral-400);transition:all var(--transition)}.cf-step.done{border-color:var(--color-secondary-300);color:var(--color-secondary-600);background:var(--color-secondary-50);cursor:pointer}.cf-step.done:hover{background:var(--color-secondary-100)}.cf-step.active{background:var(--color-secondary-600);border-color:var(--color-secondary-600);color:#fff;font-weight:var(--font-weight-semibold)}.cf-step-body{display:flex;flex-direction:column;gap:var(--spacing-md)}.cf-hint{font-size:var(--font-size-xs);color:var(--color-neutral-500);margin:0 0 var(--spacing-sm)}.day-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--color-neutral-300);background:transparent;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;color:var(--color-neutral-600);transition:all var(--transition)}.day-btn:hover{border-color:var(--color-secondary-400);color:var(--color-secondary-700)}.day-btn.active{background:var(--color-secondary-600);border-color:var(--color-secondary-600);color:#fff}.method-tabs{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.method-tab{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-neutral-300);border-radius:var(--radius-md);background:transparent;font-size:var(--font-size-sm);cursor:pointer;color:var(--color-neutral-600);transition:all var(--transition)}.method-tab:hover{border-color:var(--color-secondary-400);color:var(--color-secondary-700)}.method-tab.active{background:var(--color-secondary-600);border-color:var(--color-secondary-600);color:#fff;font-weight:var(--font-weight-semibold)}.time-chip-row{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.time-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;background:var(--color-secondary-50);border:1px solid var(--color-secondary-200);border-radius:var(--radius-full, 999px);font-size:var(--font-size-sm);color:var(--color-secondary-800)}.time-chip button{background:none;border:none;cursor:pointer;padding:0;display:flex;color:var(--color-secondary-500);transition:color var(--transition)}.time-chip button:hover{color:var(--color-red-600, #dc2626)}.time-add-row{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.custom-slots-list{border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);overflow:hidden;margin-bottom:var(--spacing-sm)}.custom-slots-header{display:grid;grid-template-columns:1fr 1fr 40px;padding:var(--spacing-xs) var(--spacing-md);background:var(--color-neutral-50);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-neutral-500);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-neutral-200)}.custom-slot-row{display:grid;grid-template-columns:1fr 1fr 40px;align-items:center;padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm);border-bottom:1px solid var(--color-neutral-100)}.custom-slot-row:last-child{border-bottom:none}.cf-settings-section{display:flex;flex-direction:column;gap:0;border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);overflow:hidden}.cf-setting-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--color-neutral-100)}.cf-setting-row:last-child{border-bottom:none}.cf-setting-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-800)}.cf-setting-desc{font-size:var(--font-size-xs);color:var(--color-neutral-500);margin-top:2px}.toggle-switch{position:relative;display:inline-flex;width:40px;height:22px;flex-shrink:0;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-neutral-300);border-radius:var(--radius-full, 999px);transition:background var(--transition)}.toggle-slider:before{content:"";position:absolute;width:16px;height:16px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform var(--transition);box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-slider{background:var(--color-secondary-600)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.cf-summary{background:var(--color-neutral-50);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);padding:var(--spacing-md);margin-top:var(--spacing-sm)}.cf-summary-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-neutral-500);margin-bottom:var(--spacing-sm)}.cf-summary-grid{display:grid;grid-template-columns:auto 1fr;gap:4px var(--spacing-md);font-size:var(--font-size-sm)}.cf-summary-grid>span:nth-child(odd){font-weight:var(--font-weight-medium);color:var(--color-neutral-500);white-space:nowrap}.cf-summary-grid>span:nth-child(2n){color:var(--color-primary-800)}.classes-toolbar{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;margin-bottom:var(--spacing-lg)}.classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.create-class-card{background:var(--color-surface);border:1px solid var(--color-neutral-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl);animation:fade-in .25s ease}.create-class-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary-800);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--color-neutral-200)}.create-class-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.create-class-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}@media(max-width:600px){.create-class-row{grid-template-columns:1fr}}.create-class-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;padding-top:var(--spacing-sm);border-top:1px solid var(--color-neutral-200)}.filter-tabs{display:flex;gap:var(--spacing-xs)}.filter-tab{padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-neutral-700);border:1px solid transparent;cursor:pointer;background:none;transition:all var(--transition-fast)}.filter-tab:hover{background:var(--color-neutral-100);color:var(--color-primary-800)}.filter-tab.active{background:var(--color-secondary-100);color:var(--color-secondary-800);border-color:var(--color-secondary-300)}.day-picker{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.modal-lg{max-width:580px!important}.step-indicator{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}.step-dot{font-size:var(--font-size-xs);padding:2px 10px;border-radius:var(--radius-full, 999px);border:1px solid var(--color-neutral-300);color:var(--color-neutral-400)}.step-dot.active{background:var(--color-secondary-600);border-color:var(--color-secondary-600);color:#fff;font-weight:var(--font-weight-semibold)}.step-dot.done{background:var(--color-secondary-50);border-color:var(--color-secondary-300);color:var(--color-secondary-700)}.step-hint{font-size:var(--font-size-sm);color:var(--color-neutral-500);margin:0 0 var(--spacing-md)}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--spacing-sm);flex:1}@media(max-width:500px){.form-row-2,.form-row-3{grid-template-columns:1fr}}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-neutral-700);cursor:pointer;margin-bottom:var(--spacing-sm)}.consent-group{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-neutral-50);border-radius:var(--radius-md);border:1px solid var(--color-neutral-200)}.parent-chips{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.parent-chip{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-secondary-200);background:var(--color-secondary-50);border-radius:var(--radius-md)}.parent-chip-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-800);display:flex;align-items:center}.parent-search-section{border-top:1px solid var(--color-neutral-200);padding-top:var(--spacing-md);margin-top:var(--spacing-sm)}.search-dropdown{border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);background:var(--color-surface);overflow:hidden;box-shadow:var(--shadow-md);margin-top:4px}.search-result-row{display:flex;flex-direction:column;align-items:flex-start;padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;width:100%;cursor:pointer;text-align:left;border-bottom:1px solid var(--color-neutral-100);transition:background var(--transition)}.search-result-row:last-child{border-bottom:none}.search-result-row:hover{background:var(--color-secondary-50)}.search-result-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-800)}.search-result-meta{font-size:var(--font-size-xs);color:var(--color-neutral-500)}.pickup-row-form{display:flex;align-items:flex-end;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-neutral-50);border-radius:var(--radius-md);border:1px solid var(--color-neutral-200);margin-bottom:var(--spacing-sm)}.class-detail-header{display:flex;align-items:flex-start;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);flex-wrap:wrap}.class-detail-icon{width:56px;height:56px;background:var(--color-secondary-50);border:1px solid var(--color-secondary-200);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--color-secondary-700);flex-shrink:0}.class-detail-title-block{flex:1;min-width:0}.class-detail-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-primary-900);letter-spacing:-.02em;line-height:var(--line-height-tight);display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.class-detail-desc{font-size:var(--font-size-base);color:var(--color-neutral-600);margin-top:var(--spacing-xs)}.class-detail-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-lg);margin-top:var(--spacing-sm)}.class-detail-meta-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-neutral-600)}.class-detail-actions{display:flex;gap:var(--spacing-sm);flex-shrink:0}.edit-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.edit-form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}@media(max-width:600px){.edit-form-row{grid-template-columns:1fr}}.edit-form-actions{display:flex;gap:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-neutral-200)}.slots-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.slot-row{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-surface);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);transition:border-color var(--transition-fast)}.slot-row:hover{border-color:var(--color-secondary-300)}.slot-date{font-weight:var(--font-weight-semibold);color:var(--color-primary-800);font-size:var(--font-size-sm);min-width:100px}.slot-time{font-size:var(--font-size-sm);color:var(--color-neutral-600);min-width:80px}.slot-capacity{font-size:var(--font-size-sm);color:var(--color-neutral-600);flex:1}.info-field-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-neutral-500);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.info-field-value{font-size:var(--font-size-sm);color:var(--color-primary-800)}.schedule-toolbar{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;margin-bottom:var(--spacing-lg)}.schedule-day-group{margin-bottom:var(--spacing-xl)}.schedule-day-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.schedule-day-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-neutral-600);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.schedule-day-today{color:var(--color-secondary-700)}.schedule-day-divider{flex:1;height:1px;background:var(--color-neutral-200)}.schedule-slot-row{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-surface);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);transition:all var(--transition-fast)}.schedule-slot-row:hover{border-color:var(--color-secondary-300);box-shadow:var(--shadow-sm);transform:translate(2px)}.schedule-slot-time{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-secondary-700);min-width:90px;flex-shrink:0}.schedule-slot-name{flex:1;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-primary-800);min-width:0;display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;text-overflow:ellipsis}.schedule-slot-age{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-secondary-700);background:var(--color-secondary-50);border:1px solid var(--color-secondary-200);border-radius:var(--radius-full, 999px);padding:1px 8px;white-space:nowrap}.schedule-slot-meta{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.schedule-range-filter{display:flex;align-items:center;gap:var(--spacing-sm)}.schedule-range-filter label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-neutral-600);white-space:nowrap}.register-slot-info{display:flex;flex-wrap:wrap;gap:var(--spacing-xl);align-items:center;background:var(--color-secondary-50);border:1px solid var(--color-secondary-200);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg);margin-bottom:var(--spacing-xl)}.register-slot-info-item{display:flex;flex-direction:column;gap:2px}.register-slot-info-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-secondary-600);text-transform:uppercase;letter-spacing:.06em}.register-slot-info-value{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-secondary-900)}.register-stats{display:flex;gap:var(--spacing-md);flex-wrap:wrap;margin-bottom:var(--spacing-lg)}.register-stat-pill{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border:1px solid var(--color-neutral-200);background:var(--color-surface);color:var(--color-neutral-700)}.register-stat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.register-stat-dot.present{background:var(--color-success)}.register-stat-dot.absent{background:var(--color-error)}.register-stat-dot.not_coming{background:var(--color-neutral-400)}.register-stat-dot.unmarked{background:var(--color-warning)}.attendance-table{width:100%;border-collapse:collapse}.attendance-table thead{background-color:var(--color-neutral-100)}.attendance-table th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-neutral-700);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--color-neutral-200);white-space:nowrap}.attendance-table td{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-neutral-200);vertical-align:middle}.attendance-table tbody tr:last-child td{border-bottom:none}.attendance-table tbody tr{transition:background-color var(--transition-fast)}.attendance-table tbody tr.present-row{background:#ecfdf5}.attendance-table tbody tr.absent-row{background:#fef2f2}.attendance-table tbody tr.not_coming-row{background:var(--color-neutral-50)}.attendance-toggle-group{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.attendance-toggle{display:flex;align-items:center;gap:4px;padding:.3rem .75rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border:1px solid var(--color-neutral-300);background:var(--color-surface);color:var(--color-neutral-600);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.attendance-toggle:hover:not(.selected-present):not(.selected-absent):not(.selected-not_coming){background:var(--color-neutral-100);color:var(--color-primary-800)}.attendance-toggle.selected-present{background:#d1fae5;color:#065f46;border-color:#6ee7b7}.attendance-toggle.selected-absent{background:#fee2e2;color:#991b1b;border-color:#fca5a5}.attendance-toggle.selected-not_coming{background:var(--color-neutral-200);color:var(--color-neutral-700);border-color:var(--color-neutral-300)}.mark-all-bar{display:flex;gap:var(--spacing-sm);align-items:center;flex-wrap:wrap}.mark-all-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-neutral-600);margin-right:var(--spacing-xs)}.register-save-bar{position:sticky;bottom:var(--spacing-md);display:flex;justify-content:flex-end;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-surface);border:1px solid var(--color-neutral-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin-top:var(--spacing-lg)}.register-save-bar-label{font-size:var(--font-size-sm);color:var(--color-neutral-600);flex:1}.crm-layout{display:grid;grid-template-columns:340px 1fr;gap:var(--spacing-lg);align-items:start}@media(max-width:768px){.crm-layout{grid-template-columns:1fr}}.crm-list-panel{background:var(--color-surface);border:1px solid var(--color-neutral-200);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm)}.crm-customer-list{display:flex;flex-direction:column;gap:2px;max-height:600px;overflow-y:auto}.crm-customer-row{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);border:none;background:transparent;cursor:pointer;text-align:left;transition:background var(--transition);width:100%}.crm-customer-row:hover{background:var(--color-neutral-100)}.crm-customer-row.selected{background:var(--color-secondary-50);outline:1px solid var(--color-secondary-200)}.crm-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-secondary-100);color:var(--color-secondary-700);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);flex-shrink:0}.crm-avatar-lg{width:52px;height:52px;font-size:var(--font-size-lg)}.crm-customer-info{flex:1;min-width:0}.crm-customer-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.crm-customer-meta{font-size:var(--font-size-xs);color:var(--color-neutral-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.crm-detail-panel{background:var(--color-surface);border:1px solid var(--color-neutral-200);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-sm);min-height:400px}.crm-detail-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:var(--color-neutral-400);font-size:var(--font-size-sm);text-align:center}.crm-detail-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-neutral-200)}.crm-detail-name{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-primary-800);margin:0 0 4px}.crm-detail-fields{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl)}.crm-detail-field{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-neutral-600)}.crm-section-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--color-neutral-400);margin-bottom:var(--spacing-sm)}.crm-enrolment-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.crm-enrolment-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);text-decoration:none;color:inherit;transition:all var(--transition)}.crm-enrolment-row:hover{border-color:var(--color-secondary-300);background:var(--color-secondary-50)}.crm-enrolment-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-800)}.crm-enrolment-meta{font-size:var(--font-size-xs);color:var(--color-neutral-500);margin-top:2px;text-transform:capitalize}.detail-tabs{display:flex;gap:2px;margin-bottom:var(--spacing-xl);border-bottom:1px solid var(--color-neutral-200);overflow-x:auto}.detail-tab{padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;font-size:var(--font-size-sm);cursor:pointer;color:var(--color-neutral-500);border-bottom:2px solid transparent;transition:all var(--transition);white-space:nowrap;margin-bottom:-1px}.detail-tab:hover{color:var(--color-secondary-600)}.detail-tab.active{color:var(--color-secondary-700);border-bottom-color:var(--color-secondary-600);font-weight:var(--font-weight-semibold)}.detail-card{padding:var(--spacing-xl)}.detail-avatar-row{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-neutral-200)}.detail-avatar{width:56px;height:56px;border-radius:50%;background:var(--color-secondary-100);color:var(--color-secondary-700);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);flex-shrink:0}.detail-full-name{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-primary-800);margin-bottom:4px}.detail-fields{display:flex;flex-direction:column;gap:var(--spacing-sm)}.detail-field{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-neutral-600)}.child-list{display:flex;flex-direction:column;gap:4px}.child-row{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);text-decoration:none;color:inherit;transition:all var(--transition)}.child-row:hover{border-color:var(--color-secondary-300);background:var(--color-secondary-50)}.child-info{flex:1;min-width:0}.child-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-800)}.child-meta{font-size:var(--font-size-xs);color:var(--color-neutral-500);text-transform:capitalize}.table-link{color:var(--color-secondary-700);text-decoration:none;font-size:var(--font-size-sm)}.table-link:hover{text-decoration:underline}.contact-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl);align-items:start}@media(max-width:768px){.contact-detail-grid{grid-template-columns:1fr}}.contact-detail-left,.contact-detail-right{display:flex;flex-direction:column;gap:var(--spacing-lg)}.detail-section{background:var(--color-surface);border:1px solid var(--color-neutral-200);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.detail-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.detail-section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary-800);display:flex;align-items:center;gap:6px;margin:0}.detail-empty-text{font-size:var(--font-size-sm);color:var(--color-neutral-400);margin:0}.parent-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.parent-card{border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md)}.parent-card-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.parent-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-800);display:flex;align-items:center}.parent-meta,.parent-contact{font-size:var(--font-size-xs);color:var(--color-neutral-500);text-transform:capitalize}.info-grid{display:flex;flex-direction:column;gap:6px}.info-item{display:flex;gap:var(--spacing-sm);font-size:var(--font-size-sm)}.info-label{font-weight:var(--font-weight-medium);color:var(--color-neutral-600);min-width:90px}.medical-text{font-size:var(--font-size-sm);color:var(--color-neutral-700);margin-bottom:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-neutral-50);border-radius:var(--radius-sm)}.consent-row{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.consent-badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:3px 10px;border-radius:var(--radius-full, 999px)}.consent-yes{background:var(--color-secondary-50);color:var(--color-secondary-700);border:1px solid var(--color-secondary-200)}.consent-no{background:var(--color-neutral-100);color:var(--color-neutral-500);border:1px solid var(--color-neutral-200)}.pickup-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.pickup-card{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-sm);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md)}.pickup-info{flex:1}.pickup-name{display:flex;align-items:center;gap:5px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-800)}.pickup-meta{font-size:var(--font-size-xs);color:var(--color-neutral-500);text-transform:capitalize}.pickup-actions{display:flex;align-items:center;gap:4px}.btn-danger{color:var(--color-red-600, #dc2626)!important}.btn-danger:hover{background:var(--color-red-50, #fef2f2)!important}.enrolment-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--spacing-lg)}.member-group-card{background:var(--color-surface);border:1px solid var(--color-neutral-200);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--spacing-md);text-decoration:none;color:inherit;transition:all var(--transition);cursor:pointer}.member-group-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--color-secondary-300)}.member-group-card-header{display:flex;align-items:flex-start;justify-content:space-between}.member-group-icon{width:40px;height:40px;background:var(--color-secondary-50);border:1px solid var(--color-secondary-200);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-secondary-700)}.member-group-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary-800);display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.member-group-class{display:flex;align-items:center;gap:5px;font-size:var(--font-size-xs);color:var(--color-neutral-500)}.member-group-desc{font-size:var(--font-size-sm);color:var(--color-neutral-600);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.member-group-footer{display:flex;align-items:center;justify-content:space-between;padding-top:var(--spacing-sm);border-top:1px solid var(--color-neutral-200);margin-top:auto}.back-link{display:inline-flex;align-items:center;gap:6px;font-size:var(--font-size-sm);color:var(--color-neutral-500);text-decoration:none;margin-bottom:var(--spacing-xs);transition:color var(--transition)}.back-link:hover{color:var(--color-secondary-600)}.member-stats-row{display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.member-stat{background:var(--color-surface);border:1px solid var(--color-neutral-200);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-xl);text-align:center;min-width:100px;box-shadow:var(--shadow-sm)}.member-stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary-800);line-height:1}.member-stat-label{font-size:var(--font-size-xs);color:var(--color-neutral-500);margin-top:4px}.filter-bar{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.filter-btn{padding:6px 16px;border-radius:var(--radius-full, 999px);border:1px solid var(--color-neutral-300);background:transparent;font-size:var(--font-size-sm);cursor:pointer;color:var(--color-neutral-600);transition:all var(--transition)}.filter-btn:hover{border-color:var(--color-secondary-400);color:var(--color-secondary-700)}.filter-btn.active{background:var(--color-secondary-600);border-color:var(--color-secondary-600);color:#fff}.data-table{width:100%;border-collapse:collapse}.data-table th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-neutral-500);border-bottom:1px solid var(--color-neutral-200);background:var(--color-neutral-50)}.data-table td{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-neutral-100);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:var(--color-neutral-50)}.member-name-cell{display:flex;flex-direction:column;gap:2px}.member-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-800)}.member-parent{font-size:var(--font-size-xs);color:var(--color-neutral-500)}
