*{margin:0;padding:0;box-sizing:border-box}:root{--color-background: #f7f7f7;--color-surface: #ffffff;--color-border: #c8c8c8;--color-border-hover: #a0a0a0;--color-text-primary: #000000;--color-text-secondary: #4a4a4a;--color-text-tertiary: #6e6e73;--color-primary: #007aff;--color-primary-hover: #0051d5;--color-blue: #007aff;--color-blue-hover: #0051d5;--color-green: #34c759;--color-orange: #ff9500;--color-red: #ff3b30;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 2px 8px rgba(0, 0, 0, .12);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .16);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", "Roboto", "Helvetica Neue", sans-serif}body{font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-background);color:var(--color-text-primary);line-height:1.5}code{font-family:SF Mono,Monaco,Inconsolata,Fira Code,Roboto Mono,monospace;font-size:.9em}#root{min-height:100vh}button,select,.card,.tab{transition:all .2s cubic-bezier(.4,0,.2,1)}.checkbox-label{display:flex;align-items:center;cursor:pointer;font-size:14px;line-height:18px;color:var(--color-text-primary);-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;margin-right:8px;margin-top:0;margin-bottom:0;flex-shrink:0;vertical-align:middle;cursor:pointer;accent-color:var(--color-primary)}.checkbox-label span{line-height:18px}.checkbox-label-filter{display:flex;align-items:center;color:var(--color-text-primary);font-size:14px;line-height:18px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:8px 12px;background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:all .2s ease}.checkbox-label-filter:hover{background:var(--color-background);border-color:var(--color-border-hover)}.checkbox-label-filter input[type=checkbox]{width:18px;height:18px;margin-right:8px;margin-top:0;margin-bottom:0;flex-shrink:0;vertical-align:middle;cursor:pointer;accent-color:var(--color-primary)}.checkbox-label-filter span{line-height:18px}.import-modal{max-width:700px;max-height:90vh;overflow-y:auto}.import-modal h2{color:#1d1d1f;margin:0 0 24px;font-size:24px;font-weight:600}.import-modal h3{color:#1d1d1f;margin:20px 0 12px;font-size:17px;font-weight:600}.file-drop-zone{border:2px dashed #007aff;border-radius:12px;padding:50px;text-align:center;background:#f5f5f7;margin-bottom:24px;transition:all .3s ease}.file-drop-zone:hover{border-color:#0051d5;background:#ebebf0;transform:translateY(-2px);box-shadow:0 4px 16px #007aff1a}.file-drop-zone p{color:#86868b;margin:8px 0;font-size:15px}.file-input-label{display:inline-block;padding:12px 24px;background:#007aff;color:#fff!important;border-radius:10px;cursor:pointer;transition:all .2s ease;font-weight:600;box-shadow:0 2px 8px #007aff33}.file-input-label:hover{background:#0051d5;transform:translateY(-2px);box-shadow:0 4px 16px #007aff4d}.file-selected{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#fff;padding:16px;border-radius:10px;border:1px solid #e5e5ea}.file-selected span{color:#1d1d1f;font-size:15px;font-weight:500}.file-selected button{padding:8px 16px;background:#ff3b30;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.file-selected button:hover{background:#ff453a;transform:translateY(-1px);box-shadow:0 3px 8px #ff3b304d}.preview-section{background:#fff;border-radius:10px;padding:16px;margin-bottom:20px;border:1px solid #e5e5ea}.preview-table{font-family:SF Mono,Monaco,Courier New,monospace;font-size:13px;max-height:200px;overflow-y:auto;background:#f5f5f7;border-radius:8px;padding:12px;border:1px solid #e5e5ea}.preview-header{color:#007aff;font-weight:600;padding:4px 0;border-bottom:1px solid #d2d2d7}.preview-row{color:#1d1d1f;padding:4px 0}.import-options{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.import-options label{display:flex;flex-direction:column;gap:8px;color:#1d1d1f;font-size:14px;font-weight:500}.import-options select,.import-options input,.import-options textarea{padding:10px 16px;border:1px solid #d2d2d7;border-radius:10px;background:#fff;color:#1d1d1f;font-size:14px;font-family:inherit;transition:all .2s ease}.import-options select::placeholder,.import-options input::placeholder,.import-options textarea::placeholder{color:#86868b}.import-options select:focus,.import-options input:focus,.import-options textarea:focus{outline:none;border-color:#007aff;box-shadow:0 0 0 4px #007aff1a}.import-options textarea{resize:vertical;min-height:80px}.import-results{padding:24px}.result-summary{text-align:center;padding:20px;border-radius:12px;font-size:20px;font-weight:600;margin-bottom:24px}.result-summary.success{background:#007aff;color:#fff;border:none}.result-summary.error{background:#ff3b30;color:#fff;border:none}.result-stats{display:flex;gap:12px;margin-bottom:24px;justify-content:center}.result-stat{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:16px 12px;border-radius:10px;background:#f5f5f7;border:none;max-width:160px}.result-stat.success{background:#34c7591a}.result-stat.warning{background:#ff95001a}.result-stat.error{background:#ff3b301a}.import-modal .result-stat .stat-label{font-size:12px;color:#6e6e73!important;text-transform:uppercase;letter-spacing:.5px;font-weight:600;text-align:center}.import-modal .result-stat .stat-value{font-size:32px;font-weight:700;color:#1d1d1f!important;line-height:1}.result-message{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;border:1px solid #e5e5ea}.result-message p{margin:12px 0;color:#1d1d1f;font-size:15px;line-height:1.5;font-weight:500}.result-message p:first-child{margin-top:0}.result-message p:last-child{margin-bottom:0}.error-details{background:#fff;border-radius:10px;padding:16px;max-height:300px;overflow-y:auto;border:1px solid #e5e5ea}.error-details table{width:100%;border-collapse:collapse}.error-details th{text-align:left;padding:12px;background:#f5f5f7;color:#1d1d1f;font-size:13px;font-weight:600;border-bottom:1px solid #e5e5ea}.error-details td{padding:12px;border-bottom:1px solid #f0f0f5;color:#1d1d1f;font-size:13px}.error-details td:first-child{color:#f57c00;font-weight:600}.error-details td:last-child{color:#c62828}.import-modal .modal-actions{position:sticky;bottom:0;background:#fff;padding-top:20px;margin-top:20px;border-top:1px solid #e5e5ea;z-index:10}.waitlist-dashboard{padding:20px;background:#f5f5f7;min-height:100vh}.stats-summary{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;justify-content:center}.waitlist-dashboard .stat-card{background:linear-gradient(135deg,#007aff,#0051d5)!important;border-radius:12px;padding:20px;min-width:140px;display:flex;flex-direction:column;gap:8px;box-shadow:0 2px 12px #007aff26;transition:all .2s ease}.waitlist-dashboard .stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px #007aff40}.waitlist-dashboard .stat-label{font-size:12px;color:#fffffff2!important;text-transform:uppercase;letter-spacing:.8px;font-weight:700;margin-bottom:4px;display:block}.waitlist-dashboard .stat-value{font-size:36px;font-weight:700;color:#fff!important;line-height:1;display:block}.filters-section{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.filters-section .btn-outline{background:#fff;color:#007aff;border:1.5px solid #007aff;padding:11px 22px;border-radius:10px}.filters-section .btn-outline:hover{background:#007aff;border-color:#007aff;color:#fff}.search-input{flex:1;min-width:200px;padding:10px 16px;border:1px solid #d2d2d7;border-radius:10px;background:#fff;color:#1d1d1f;font-size:14px;transition:all .2s ease}.search-input::placeholder{color:#86868b}.search-input:focus{outline:none;border-color:#007aff;box-shadow:0 0 0 4px #007aff1a}.filter-select{padding:10px 16px;border:1px solid #d2d2d7;border-radius:10px;background:#fff;color:#1d1d1f;font-size:14px;cursor:pointer;transition:all .2s ease}.filter-select:focus{outline:none;border-color:#007aff;box-shadow:0 0 0 4px #007aff1a}.bulk-actions{background:#fff;padding:14px 18px;border-radius:12px;display:flex;align-items:center;gap:12px;margin-bottom:16px;border:1px solid #e5e5ea;box-shadow:0 2px 8px #0000000f}.bulk-actions span{color:#1d1d1f;font-size:14px;font-weight:500}.table-container{background:#fff;border-radius:12px;overflow:hidden;margin-bottom:20px;border:1px solid #e5e5ea;box-shadow:0 2px 8px #0000000f}.data-table{width:100%;border-collapse:collapse}.data-table th{background:#f5f5f7;color:#1d1d1f;padding:16px;text-align:left;font-weight:600;border-bottom:1px solid #e5e5ea;font-size:12px;text-transform:uppercase;letter-spacing:.6px}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s ease}.data-table th.sortable:hover{background:#ebebf0}.data-table td{padding:16px;border-bottom:1px solid #f0f0f5;color:#1d1d1f;font-size:14px}.data-table tbody tr{transition:background .15s ease}.data-table tbody tr:hover{background:#f9f9fb}.data-table tr.deleted-row{background:#fff8f8}.data-table tr.deleted-row:hover{background:#ffefef}.data-table td.strikethrough{text-decoration:line-through;color:#424242;font-style:italic}.status-badge{display:inline-block;padding:5px 12px;border-radius:14px;font-size:12px;font-weight:600;text-transform:capitalize}.status-badge.pending{background:#fff8e1;color:#f57c00;border:1px solid #ffe0b2}.status-badge.invited{background:#e3f2fd;color:#1976d2;border:1px solid #bbdefb}.status-badge.converted{background:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}.status-badge.bounced{background:#ffebee;color:#c62828;border:1px solid #ffcdd2}.status-badge.deleted{background:#f5f5f5;color:#616161;border:1px solid #e0e0e0;margin-left:6px}.source-badge{display:inline-block;padding:5px 12px;border-radius:8px;font-size:12px;background:#f5f5f7;color:#1d1d1f;border:1px solid #e5e5ea;font-weight:500}.btn{padding:10px 20px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 6px #00000014}.btn-primary{background:#007aff;color:#fff}.btn-primary:hover{background:#0051d5;transform:translateY(-1px);box-shadow:0 4px 12px #007aff40}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#f5f5f7;color:#1d1d1f;border:1px solid #e5e5ea}.btn-secondary:hover{background:#ebebf0;border-color:#d2d2d7}.btn-outline{background:transparent;color:#007aff;border:1.5px solid #007aff;padding:11px 22px;border-radius:20px;font-size:14px;font-weight:500;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:none;letter-spacing:-.01em}.btn-outline:hover{background:#007aff0f;border-color:#06c;color:#06c;box-shadow:none}.btn-outline:active{background:#007aff1f;transform:scale(.98);transition-duration:.1s}.btn-danger{background:#ff3b30;color:#fff}.btn-success{background:#34c759;color:#fff;border:none;padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 6px #34c75940}.btn-success:hover{background:#28a745;transform:translateY(-1px);box-shadow:0 4px 12px #34c75959}.btn-success:active{transform:translateY(0)}.btn-danger:hover{background:#ff453a;transform:translateY(-1px);box-shadow:0 4px 12px #ff3b304d}.btn-action{padding:8px 16px;font-size:13px;border:none;border-radius:8px;cursor:pointer;background:#007aff;color:#fff;transition:all .2s ease;font-weight:600}.btn-action:hover{background:#0051d5;transform:translateY(-1px);box-shadow:0 3px 8px #007aff33}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;padding:20px;background:#fff;border-radius:12px;border:1px solid #e5e5ea;box-shadow:0 2px 8px #0000000f}.pagination button{padding:10px 18px;border:1px solid #d2d2d7;border-radius:10px;background:#fff;color:#1d1d1f;cursor:pointer;transition:all .2s ease;font-weight:500}.pagination button:hover:not(:disabled){background:#007aff;border-color:#007aff;color:#fff;transform:translateY(-1px);box-shadow:0 3px 8px #007aff33}.pagination button:disabled{opacity:.4;cursor:not-allowed;background:#f5f5f7;color:#86868b;border-color:#e5e5ea}.pagination span{color:#1d1d1f;font-size:14px;font-weight:500}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:16px;padding:28px;max-width:500px;width:90%;box-shadow:0 20px 60px #0000004d;border:1px solid #e5e5ea;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-content h3{color:#1d1d1f;margin:0 0 16px;font-size:20px;font-weight:600}.modal-content p{color:#1d1d1f;margin:8px 0;line-height:1.5}.modal-content label{display:block;color:#1d1d1f;font-size:14px;margin:16px 0 8px;font-weight:500}.modal-content textarea{width:100%;padding:12px;border:1px solid #d2d2d7;border-radius:10px;background:#fff;color:#1d1d1f;font-size:14px;font-family:inherit;resize:vertical;margin-top:8px;transition:all .2s ease}.modal-content textarea::placeholder{color:#86868b}.modal-content textarea:focus{outline:none;border-color:#007aff;box-shadow:0 0 0 4px #007aff1a}.modal-actions{display:flex;gap:12px;margin-top:24px;justify-content:flex-end}.dashboard-loading{display:flex;align-items:center;justify-content:center;padding:60px;color:#1d1d1f;font-size:16px;font-weight:500}.grant-modal{max-width:600px;max-height:80vh;overflow-y:auto}.campaign-info{background:linear-gradient(135deg,#f0f9f4,#e6f7ed);border:1px solid rgba(26,95,63,.2);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.campaign-info h3{margin:0 0 var(--spacing-sm) 0;font-size:18px;color:var(--color-text-primary)}.campaign-code{margin:var(--spacing-sm) 0;font-size:14px;color:var(--color-text-secondary)}.campaign-code strong{color:var(--color-primary);font-family:SF Mono,Monaco,monospace;font-size:16px}.selected-count{margin:var(--spacing-sm) 0 0 0;font-size:13px;color:var(--color-text-secondary);font-weight:600}.form-group{margin-bottom:var(--spacing-md)}.form-group input[type=number]{width:100%;padding:10px 12px;border:2px solid var(--color-border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-family);transition:border-color .2s}.form-group input[type=number]:focus{outline:none;border-color:var(--color-primary)}.results-section{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.results-section h3{margin:0 0 var(--spacing-md) 0;font-size:18px;color:var(--color-text-primary)}.results-summary{display:flex;gap:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-background);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md)}.results-summary p{margin:0;font-size:14px;font-weight:600}.results-list{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);max-height:300px;overflow-y:auto}.result-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface)}.result-item.success{background:#34c7590d;border-color:#34c75933}.result-item.failed{background:#ff3b300d;border-color:#ff3b3033}.result-icon{font-size:20px;line-height:1;flex-shrink:0}.result-details{display:flex;flex-direction:column;gap:4px;flex:1}.result-details strong{font-size:14px;color:var(--color-text-primary)}.result-status{font-size:12px;color:var(--color-text-secondary);font-weight:600}.result-code{font-size:12px;color:var(--color-primary);font-family:SF Mono,Monaco,monospace}.result-error{font-size:12px;color:#ff3b30;font-style:italic}.email-status{font-size:12px;font-weight:500;margin-top:4px}.email-status.sent{color:var(--color-primary)}.email-status.failed{color:#d97706}.results-summary .email-success{color:var(--color-primary)}.results-summary .email-warning{color:#d97706}.email-warning-banner{background:#fef3c7;border:1px solid #f59e0b;border-radius:var(--radius-sm);padding:var(--spacing-sm);margin-bottom:var(--spacing-md);color:#92400e;font-size:13px;font-weight:500;line-height:1.5}.tasks-dashboard{padding:20px;background:#f5f5f7;min-height:100vh}.tasks-dashboard .error-banner{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:16px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between}.tasks-dashboard .error-banner strong{color:#856404;display:block;margin-bottom:4px}.tasks-dashboard .error-banner span{color:#856404}.tasks-dashboard .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin-bottom:24px}.tasks-dashboard .stat-card{background:linear-gradient(135deg,#007aff,#0051d5);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:8px;box-shadow:0 2px 12px #007aff26;transition:all .2s ease}.tasks-dashboard .stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px #007aff40}.tasks-dashboard .stat-card h3{font-size:12px;color:#fffffff2;text-transform:uppercase;letter-spacing:.8px;font-weight:700;margin:0}.tasks-dashboard .stat-card .stat-value{font-size:36px;font-weight:700;color:#fff;line-height:1}.tasks-dashboard .filters-row{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.tasks-dashboard .status-filters{display:flex;gap:8px}.tasks-dashboard .status-filters button{background:#fff;color:#007aff;border:1.5px solid #007aff;padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.tasks-dashboard .status-filters button:hover{background:#e3f2fd}.tasks-dashboard .status-filters button.active{background:#007aff;color:#fff}.tasks-dashboard .search-input{flex:1;min-width:200px;padding:10px 16px;border:1px solid #d2d2d7;border-radius:10px;background:#fff;font-size:14px;transition:border-color .2s}.tasks-dashboard .search-input:focus{outline:none;border-color:#007aff;box-shadow:0 0 0 3px #007aff1a}.tasks-dashboard .table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px #00000014;margin-bottom:20px}.tasks-dashboard .data-table{width:100%;border-collapse:collapse}.tasks-dashboard .data-table thead{background:#f8f9fa;border-bottom:2px solid #e5e5ea}.tasks-dashboard .data-table th{padding:16px;text-align:left;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#1d1d1f}.tasks-dashboard .data-table td{padding:16px;border-bottom:1px solid #e5e5ea;font-size:14px;color:#1d1d1f}.tasks-dashboard .data-table tbody tr:hover{background:#f8f9fa}.tasks-dashboard .task-title{font-weight:600;color:#1d1d1f}.tasks-dashboard .user-info{display:flex;align-items:center;gap:12px}.tasks-dashboard .user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.tasks-dashboard .user-details{display:flex;flex-direction:column;gap:2px}.tasks-dashboard .user-name{font-weight:600;color:#1d1d1f;font-size:14px}.tasks-dashboard .user-email{font-size:12px;color:#86868b}.tasks-dashboard .user-unknown{color:#86868b;font-style:italic}.tasks-dashboard .status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.tasks-dashboard .status-badge.active{background:#e3f2fd;color:#1976d2}.tasks-dashboard .status-badge.completed{background:#e8f5e9;color:#388e3c}.tasks-dashboard .overdue-date{color:#d32f2f;font-weight:600}.tasks-dashboard .created-date{color:#86868b;font-size:13px}.tasks-dashboard .pagination{display:flex;justify-content:center;align-items:center;gap:16px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014}.tasks-dashboard .pagination button{padding:10px 20px;background:#007aff;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.tasks-dashboard .pagination button:hover:not(:disabled){background:#0051d5;transform:translateY(-1px)}.tasks-dashboard .pagination button:disabled{background:#e5e5ea;color:#86868b;cursor:not-allowed}.tasks-dashboard .pagination span{font-size:14px;color:#1d1d1f}@media (max-width: 1024px){.tasks-dashboard .created-date{display:none}.tasks-dashboard .data-table th:last-child,.tasks-dashboard .data-table td:last-child{display:none}}@media (max-width: 768px){.tasks-dashboard{padding:12px}.tasks-dashboard .stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.tasks-dashboard .stat-card{padding:16px}.tasks-dashboard .stat-card .stat-value{font-size:28px}.tasks-dashboard .filters-row{flex-direction:column;align-items:stretch}.tasks-dashboard .status-filters{width:100%}.tasks-dashboard .status-filters button{flex:1;padding:12px}.tasks-dashboard .search-input{width:100%}.tasks-dashboard .table-container{overflow-x:auto}.tasks-dashboard .data-table{min-width:600px}.tasks-dashboard .data-table th,.tasks-dashboard .data-table td{padding:12px 8px;font-size:13px}.tasks-dashboard .user-info{gap:8px}.tasks-dashboard .user-avatar{width:28px;height:28px}.tasks-dashboard .user-name{font-size:13px}.tasks-dashboard .user-email{font-size:11px}.tasks-dashboard .pagination{flex-direction:column;gap:12px}.tasks-dashboard .pagination button{width:100%}}@media (max-width: 480px){.tasks-dashboard .stats-grid{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background:#fff;border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:var(--color-text-primary)}.modal-close{background:none;border:none;font-size:32px;line-height:1;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all .2s ease}.modal-close:hover{background:#0000000d;color:var(--color-text-primary)}.modal-content form{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:var(--spacing-md);scrollbar-gutter:stable}.form-group{display:flex;flex-direction:column;gap:10px;margin-bottom:8px}.form-group label{font-size:13px;font-weight:600;color:var(--color-text-primary)}.required{color:var(--color-error)}.form-group input,.form-group textarea,.form-group select{padding:10px 12px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;font-family:var(--font-family);color:var(--color-text-primary);transition:all .2s ease}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1a5f3f1a}.form-group input.error,.form-group textarea.error,.form-group select.error{border-color:var(--color-error)}.form-group input:disabled,.form-group textarea:disabled,.form-group select:disabled{background:var(--color-bg-secondary);cursor:not-allowed;opacity:.6}.form-group textarea{resize:vertical;min-height:80px}.error-message{font-size:12px;color:var(--color-error);margin-top:-4px}.field-help{font-size:12px;color:var(--color-text-secondary);margin-top:-4px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.alert{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:14px}.alert-error{background:#ff3b301a;color:var(--color-error);border:1px solid rgba(255,59,48,.2)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--color-border);background:var(--color-bg-secondary)}.modal-actions button{min-width:140px;padding:12px 24px;font-size:15px;font-weight:600}.revoke-modal{max-width:550px}.revoke-warning{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);background:#ff95001a;border:2px solid rgba(255,149,0,.3);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.warning-icon{font-size:24px;line-height:1;flex-shrink:0}.revoke-warning p{margin:0;font-size:14px;color:#ff9500;font-weight:600;line-height:1.5}.grant-details{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.detail-row{display:flex;justify-content:space-between;align-items:baseline;padding:var(--spacing-xs) 0;border-bottom:1px solid rgba(0,0,0,.05)}.detail-row:last-child{border-bottom:none}.detail-label{font-size:13px;color:var(--color-text-secondary);font-weight:600}.detail-value{font-size:14px;color:var(--color-text-primary);text-align:right}.detail-value.user-id{font-family:SF Mono,Monaco,monospace;font-size:12px}.detail-value.code-value{font-family:SF Mono,Monaco,monospace;font-size:14px;font-weight:600;color:var(--color-primary)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-size:14px;font-weight:600;color:var(--color-text-primary)}.required{color:#ff3b30}.form-group textarea{width:100%;padding:10px 12px;border:2px solid var(--color-border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-family);resize:vertical;transition:border-color .2s}.form-group textarea:focus{outline:none;border-color:var(--color-primary)}.form-group textarea:disabled{background:var(--color-background);cursor:not-allowed;opacity:.6}.character-count{margin-top:var(--spacing-xs);font-size:12px;color:var(--color-text-tertiary);text-align:right}.error-message{padding:var(--spacing-sm);background:#ff3b301a;border:1px solid rgba(255,59,48,.3);border-radius:var(--radius-sm);color:#ff3b30;font-size:14px;margin-bottom:var(--spacing-md)}.btn-danger{padding:10px 24px;background:#ff3b30;border:2px solid #ff3b30;border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s}.btn-danger:hover:not(:disabled){background:#cc2e24;border-color:#cc2e24;transform:translateY(-2px);box-shadow:0 4px 12px #ff3b304d}.btn-danger:disabled{opacity:.5;cursor:not-allowed;transform:none}.campaign-details{flex:1;display:flex;flex-direction:column;gap:var(--spacing-lg)}.details-header{display:flex;align-items:center;gap:var(--spacing-md)}.details-header h2{margin:0;font-size:24px;font-weight:600;color:var(--color-text-primary)}.btn-back{padding:8px 16px;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:var(--color-text-primary);cursor:pointer;transition:all .2s}.btn-back:hover{background:var(--color-background);border-color:var(--color-primary);color:var(--color-primary)}.campaign-overview{background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:0 2px 8px #00000014}.overview-section{margin-bottom:var(--spacing-lg)}.campaign-description{margin:0 0 var(--spacing-md) 0;font-size:16px;color:var(--color-text-secondary);line-height:1.6}.campaign-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.meta-item{font-size:13px;color:var(--color-text-secondary)}.meta-item strong{color:var(--color-text-primary);font-weight:600}.campaign-metrics{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}@media (max-width: 1024px){.campaign-metrics{grid-template-columns:repeat(3,1fr)}}.metric-card{text-align:center}.metric-label{font-size:11px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600;margin-bottom:4px}.metric-value{font-size:24px;font-weight:700;color:var(--color-primary)}.metric-sublabel{font-size:10px;color:var(--color-text-tertiary);margin-top:2px;line-height:1.3}.grants-section{background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.grants-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);gap:var(--spacing-md);flex-wrap:wrap}.grants-header h3{margin:0;font-size:18px;font-weight:600;color:var(--color-text-primary)}.grants-filters{display:flex;gap:var(--spacing-sm)}.status-filter,.email-search{padding:8px 12px;border:2px solid var(--color-border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-family);transition:border-color .2s}.status-filter:focus,.email-search:focus{outline:none;border-color:var(--color-primary)}.email-search{min-width:200px}.grants-loading,.grants-empty,.campaign-details-loading,.campaign-details-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--color-text-secondary);font-size:16px}.empty-hint{font-size:14px;color:var(--color-text-tertiary);margin-top:var(--spacing-xs)}.grants-table-container{overflow-x:auto;margin-bottom:var(--spacing-md)}.grants-table{width:100%;border-collapse:collapse}.grants-table thead{background:linear-gradient(135deg,#1a5f3f0d,#1a5f3f05)}.grants-table th{text-align:left;padding:12px 16px;font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--color-border)}.grants-table td{padding:12px 16px;font-size:14px;color:var(--color-text-primary);border-bottom:1px solid rgba(0,0,0,.05)}.grants-table tbody tr:hover{background:#1a5f3f05}.user-id{font-family:SF Mono,Monaco,monospace;font-size:13px;color:var(--color-text-secondary)}.code-cell{font-family:SF Mono,Monaco,monospace;font-size:13px;font-weight:600;color:var(--color-primary)}.grant-status-badge{display:inline-block;padding:4px 10px;border-radius:var(--radius-sm);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.grant-status-badge.active{background:#34c7591a;color:#34c759}.grant-status-badge.revoked{background:#ff3b301a;color:#ff3b30}.btn-revoke{padding:6px 12px;background:transparent;border:2px solid #ff3b30;border-radius:var(--radius-sm);font-size:12px;font-weight:600;color:#ff3b30;cursor:pointer;transition:all .2s}.btn-revoke:hover{background:#ff3b30;color:#fff}.revoked-label{font-size:12px;color:var(--color-text-tertiary);font-style:italic}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.btn-pagination{padding:8px 16px;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:var(--color-text-primary);cursor:pointer;transition:all .2s}.btn-pagination:hover:not(:disabled){background:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-pagination:disabled{opacity:.4;cursor:not-allowed}.pagination-info{font-size:14px;color:var(--color-text-secondary)}@media (max-width: 768px){.campaign-metrics{grid-template-columns:1fr}.grants-header{flex-direction:column;align-items:flex-start}.grants-filters{width:100%;flex-direction:column}.email-search{width:100%}.grants-table{font-size:12px}.grants-table th,.grants-table td{padding:8px 12px}}.campaigns-dashboard{flex:1;display:flex;flex-direction:column}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.dashboard-header h2{margin:0;font-size:20px;font-weight:600;color:var(--color-text-primary)}.dashboard-header .btn-primary{padding:10px 24px;font-size:14px;font-weight:600;white-space:nowrap;min-width:160px}.campaigns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-md)}.campaign-card{background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:0 2px 8px #00000014;transition:all .3s ease;display:flex;flex-direction:column;gap:var(--spacing-md)}.campaign-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026;border-color:var(--color-primary)}.campaign-card-header{display:flex;justify-content:space-between;align-items:start;gap:var(--spacing-sm)}.campaign-card-header h3{margin:0;font-size:18px;font-weight:600;color:var(--color-text-primary);flex:1}.campaign-description{margin:0;font-size:14px;color:var(--color-text-secondary);line-height:1.5}.campaign-type{display:flex;gap:var(--spacing-xs)}.type-badge{display:inline-block;padding:4px 12px;background:#1a5f3f1a;color:var(--color-primary);border-radius:var(--radius-md);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--radius-md);font-size:12px;font-weight:600;white-space:nowrap}.status-badge.active{background:#34c7591a;color:#34c759}.status-badge.inactive{background:#ff95001a;color:#ff9500}.status-badge.ended{background:#ff3b301a;color:#ff3b30}.campaign-metrics-table{width:100%;border-collapse:collapse;margin:var(--spacing-md) 0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.campaign-metrics-table thead th{font-size:11px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600;text-align:center;padding:var(--spacing-sm) var(--spacing-xs);border-bottom:1px solid rgba(0,0,0,.05)}.campaign-metrics-table tbody td{font-size:20px;font-weight:700;color:var(--color-primary);text-align:center;padding:var(--spacing-sm) var(--spacing-xs)}.campaign-dates{display:flex;flex-direction:column;gap:var(--spacing-xs)}.date-info{display:flex;justify-content:space-between;font-size:13px}.date-label{color:var(--color-text-secondary)}.date-value{color:var(--color-text-primary);font-weight:500}.campaign-actions{display:flex;gap:var(--spacing-sm);margin-top:auto}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-lg);text-align:center;color:var(--color-text-secondary)}.empty-state p{margin:0 0 var(--spacing-md) 0;font-size:16px}.dashboard-loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--color-text-secondary);font-size:16px}.dashboard-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--color-error)}.dashboard-error p{margin:0 0 var(--spacing-md) 0}.modal-placeholder{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:0 8px 32px #0003;z-index:1000}.modal-placeholder:before{content:"";position:fixed;inset:0;background:#00000080;z-index:-1}.dashboard{flex:1;display:flex;flex-direction:column}.dashboard-tabs{display:flex;gap:var(--spacing-xs);padding:0;background:transparent;border-bottom:none;margin-bottom:var(--spacing-lg)}.dashboard-tabs button{padding:10px 20px;border:2px solid transparent;background:transparent;color:var(--color-text-secondary);font-size:14px;font-weight:600;cursor:pointer;border-radius:var(--radius-md);position:relative;font-family:var(--font-family)}.dashboard-tabs button:hover{color:var(--color-text-primary);background:#007aff0d;border-color:#007aff33}.dashboard-tabs button.active{color:#007aff;background:#007aff1a;border-color:#007aff;font-weight:700}.dashboard-content{flex:1}.dashboard-content h2{margin:0 0 var(--spacing-lg) 0;font-size:20px;font-weight:600;color:var(--color-text-primary);letter-spacing:-.3px}.dashboard-loading{display:flex;align-items:center;justify-content:center;flex:1;font-size:15px;color:var(--color-text-secondary);min-height:400px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.stat-card{background:linear-gradient(135deg,#fff,#fafafa);padding:var(--spacing-xl);border-radius:var(--radius-lg);border:2px solid var(--color-border);box-shadow:var(--shadow-lg);transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026;border-color:#007aff}.stat-card h3{margin:0 0 var(--spacing-md) 0;font-size:11px;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:1px}.stat-value{font-size:40px;font-weight:700;color:#007aff;margin-bottom:var(--spacing-sm);letter-spacing:-1px}.stat-detail{font-size:13px;color:var(--color-text-secondary);line-height:1.4}.data-table{width:100%;background:var(--color-surface);border-radius:var(--radius-lg);border:2px solid var(--color-border);overflow:hidden;border-collapse:separate;border-spacing:0;box-shadow:var(--shadow-lg)}.data-table thead{background:linear-gradient(180deg,#fafafa,#f5f5f5);border-bottom:2px solid var(--color-border)}.data-table th{padding:14px 18px;text-align:left;font-size:11px;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:1px;border-bottom:2px solid var(--color-border)}.data-table td{padding:14px 16px;border-top:1px solid var(--color-border);font-size:14px;color:var(--color-text-primary)}.data-table tbody tr{transition:background-color .15s ease}.data-table tbody tr:hover{background:#007aff0a}.data-table tbody tr:first-child td{border-top:none}.status-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-sm);font-size:12px;font-weight:600;line-height:1}.status-badge.active{background:#34c7591a;color:var(--color-green)}.status-badge.inactive{background:#0000000d;color:var(--color-text-tertiary)}.status-badge.completed{background:#007aff1a;color:var(--color-blue)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);min-height:300px;text-align:center}.empty-state-icon{font-size:48px;margin-bottom:var(--spacing-md);opacity:.3}.empty-state-text{font-size:15px;color:var(--color-text-secondary)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#f5f5f7,#fff);padding:20px;font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.login-card{background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:18px;box-shadow:0 4px 24px #0000000f,0 0 1px #0000000a;max-width:440px;width:100%;overflow:hidden;border:1px solid rgba(0,0,0,.04)}.login-header{background:transparent;color:#1d1d1f;padding:48px 32px 24px;text-align:center}.login-header h1{margin:0 0 16px;font-size:32px;font-weight:600;letter-spacing:-.5px;color:#1d1d1f}.login-header .environment-badge{display:inline-block;padding:6px 14px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px}.login-header .environment-badge.production{background-color:#ff3b30;color:#fff}.login-header .environment-badge.local{background-color:#0071e3;color:#fff}.login-error{background-color:#fff5f5;border-left:3px solid #ff3b30;color:#c41e3a;padding:16px 32px;margin:0;font-size:14px;font-weight:500;line-height:1.5}.login-content{padding:32px 32px 40px;text-align:center}.login-description{color:#6e6e73;font-size:17px;line-height:1.47;margin:0 0 32px;font-weight:400}.google-login-button{background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:12px;color:#1d1d1f;cursor:pointer;display:inline-flex;align-items:center;gap:12px;font-size:17px;font-weight:500;padding:16px 32px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000000a,0 1px 2px #0000000f}.google-login-button:hover{background:#fafafa;border-color:#0000001f;box-shadow:0 4px 16px #00000014,0 2px 4px #00000014;transform:translateY(-2px)}.google-login-button:active{transform:translateY(0);box-shadow:0 2px 8px #0000000a,0 1px 2px #0000000f}.login-footer{background:#f7f7f7cc;border-top:1px solid rgba(0,0,0,.06);padding:24px 32px;text-align:center}.login-notice{color:#86868b;font-size:14px;margin:0;font-weight:400;line-height:1.5}.app{display:flex;flex-direction:column;min-height:100vh;background:var(--color-background)}.app-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) var(--spacing-xl);background:#000;border-bottom:3px solid #000000;box-shadow:var(--shadow-lg)}.app-header h1{margin:0;font-size:24px;font-weight:700;color:#fff;letter-spacing:-.5px}.app-main{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding:var(--spacing-lg);max-width:1400px;width:100%;margin:0 auto}
