*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:#1f2937;background:linear-gradient(135deg,#f8fffe,#f0f9f7);min-height:100vh}.app{display:flex;flex-direction:column;min-height:100vh}.header{background:linear-gradient(135deg,#0d3a34,#165a52);color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 6px #0d3a3426;flex-shrink:0}.header-left{display:flex;align-items:center;gap:1rem}.header-logo{height:32px;width:auto}.header-title{font-size:1.5rem;font-weight:700;color:#fff;margin:0}.header-right{display:flex;align-items:center;gap:1rem}.logo{font-size:1.5rem;font-weight:700;color:#fff;text-decoration:none}.user-info{display:flex;align-items:center;gap:1rem}.main-content{flex:1;padding:2rem;max-width:100%;min-height:calc(100vh - 80px);width:100%}.page-title{font-size:2rem;font-weight:700;background:linear-gradient(135deg,#0d3a34,#165a52);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1.5rem}.filters{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;align-items:center}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-label{font-weight:500;color:#0d3a34;white-space:nowrap}.search-container{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:.75rem;color:#0d3a34;z-index:1}.search-loading{position:absolute;right:.75rem;color:#0d3a34;z-index:1;font-size:.875rem}.search-input{padding:.5rem 2.5rem;border:2px solid #e5f3f1;border-radius:.5rem;background:#fff;font-size:.875rem;width:250px;transition:all .2s ease}.search-input:focus{outline:none;border-color:#dcea2c;box-shadow:0 0 0 3px #dcea2c1a}.table-container{background:#fff;border-radius:1rem;box-shadow:0 4px 6px #0d3a341a;overflow:hidden;margin-bottom:1rem;width:100%;overflow-x:auto;position:relative;border:1px solid #e5f3f1}.table{width:100%;border-collapse:collapse;min-width:1000px;table-layout:fixed}.table thead{background:linear-gradient(135deg,#0d3a34,#165a52)}.table th{padding:1rem .75rem;text-align:center;font-weight:600;color:#fff;border-bottom:none;white-space:nowrap;font-size:.875rem}.table th:nth-child(1){width:180px}.table th:nth-child(2){width:80px}.table th:nth-child(3){width:150px}.table th:nth-child(4){width:100px}.table th:nth-child(5){width:90px}.table th:nth-child(6){width:80px}.table th:nth-child(7){width:90px}.table th:nth-child(8){width:120px}.table td{padding:.875rem .75rem;border-bottom:1px solid #e5f3f1;vertical-align:middle;font-size:.875rem}.table tbody tr:nth-child(2n){background:linear-gradient(135deg,#f8fffe,#f0f9f7)}.table tbody tr:hover{background:linear-gradient(135deg,#e5f3f1,#ddf2ed);transform:translateY(-1px);transition:all .2s ease}.user-cell{display:flex;align-items:center;gap:.5rem;min-width:160px;max-width:200px}.user-avatar-small{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid #dcea2c;flex-shrink:0}.user-avatar-placeholder-small{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#0d3a34,#165a52);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.75rem;border:2px solid #dcea2c;flex-shrink:0}.user-info-cell{flex:1;min-width:0}.user-name-cell{display:flex;align-items:center;gap:.375rem;margin-bottom:.125rem}.user-name-text{font-weight:600;color:#0d3a34;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.875rem}.onboarding-dot{width:6px;height:6px;border-radius:50%;background:#dcea2c;flex-shrink:0;box-shadow:0 0 0 2px #dcea2c33}.user-email-text{color:#6b7280;font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.user-badge{display:inline-block;padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:600;text-transform:capitalize}.user-badge.teacher{background:linear-gradient(135deg,#dcea2c,#b8d01f);color:#0d3a34}.user-badge.student{background:linear-gradient(135deg,#0d3a34,#165a52);color:#fff}.table-text{color:#4b5563;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;max-width:120px}.connections-cell{display:flex;gap:.25rem;align-items:center}.connection-badge{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-size:.7rem;font-weight:600;color:#fff}.connection-badge.google{background:linear-gradient(135deg,#dcea2c,#b8d01f);color:#0d3a34}.connection-badge.clever{background:linear-gradient(135deg,#0d3a34,#165a52);color:#fff}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:600;text-transform:capitalize}.status-badge.complete{background:linear-gradient(135deg,#dcea2c,#b8d01f);color:#0d3a34}.status-badge.pending{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border:1px solid #f59e0b}.table-actions{display:flex;gap:.375rem;justify-content:center;align-items:center}.btn-icon{padding:.375rem;font-size:.875rem;border-radius:.5rem;font-weight:500;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;border:2px solid transparent}.btn-icon:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0d3a3433}.btn-xs{padding:.375rem .5rem;font-size:.7rem;border-radius:.375rem;font-weight:500}.empty-row{text-align:center;padding:3rem 1rem!important}.empty-state-inline{display:flex;align-items:center;justify-content:center;gap:.5rem;color:#6b7280;font-size:.875rem}.empty-state-inline span:first-child{font-size:1.5rem;opacity:.7}.search-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#ffffffe6,#f0f9f7e6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10;border-radius:1rem}.search-overlay-content{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:#0d3a34;font-size:.875rem;font-weight:500}.search-overlay-content .spinner{width:32px;height:32px;border-width:3px;border-color:#e5f3f1;border-top-color:#dcea2c}.loading-more{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem;color:#0d3a34;font-size:.875rem;font-weight:500}.loading-more .spinner{width:28px;height:28px;border-width:3px;border-color:#e5f3f1;border-top-color:#dcea2c}.end-of-results{text-align:center;padding:2rem;color:#6b7280;font-size:.875rem;border-top:2px solid #e5f3f1;margin-top:1rem;background:linear-gradient(135deg,#f8fffe,#f0f9f7);border-radius:.5rem}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.user-form-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.user-form{background:linear-gradient(135deg,#fff,#f8fffe);border-radius:1rem;padding:2rem;box-shadow:0 4px 6px #0d3a341a;width:100%;max-width:none;border:1px solid #e5f3f1}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group.full-width{grid-column:1 / -1}.form-label{font-weight:600;color:#0d3a34;font-size:.875rem}.form-input,.form-select,.form-textarea{padding:.75rem;border:2px solid #e5f3f1;border-radius:.5rem;background:#fff;font-size:.875rem;transition:all .2s ease;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#dcea2c;box-shadow:0 0 0 3px #dcea2c1a}.form-textarea{resize:vertical;min-height:100px}.checkbox-group{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;cursor:pointer;color:#0d3a34;font-weight:500}.form-checkbox{width:auto;margin:0;accent-color:#dcea2c}.form-actions{display:flex;gap:1rem;justify-content:flex-end;flex-wrap:wrap;margin-top:2rem}.btn{padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;font-size:.875rem;border:none;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;white-space:nowrap;position:relative;overflow:hidden}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#dcea2c,#b8d01f);color:#0d3a34;border:2px solid transparent}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#b8d01f,#a4c117);transform:translateY(-2px);box-shadow:0 4px 12px #dcea2c4d}.btn-secondary{background:linear-gradient(135deg,#f8fffe,#e5f3f1);color:#0d3a34;border:2px solid #e5f3f1}.btn-secondary:hover:not(:disabled){background:linear-gradient(135deg,#e5f3f1,#d1ede7);border-color:#dcea2c;transform:translateY(-2px);box-shadow:0 4px 12px #0d3a341a}.btn-warning{background:linear-gradient(135deg,#dcea2c,#b8d01f);color:#0d3a34;border:2px solid transparent}.btn-warning:hover:not(:disabled){background:linear-gradient(135deg,#b8d01f,#a4c117);transform:translateY(-2px);box-shadow:0 4px 12px #dcea2c4d}.btn-danger{background:linear-gradient(135deg,#0d3a34,#165a52);color:#fff;border:2px solid transparent}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#165a52,#1f7a6b);transform:translateY(-2px);box-shadow:0 4px 12px #0d3a344d}.btn-small{padding:.5rem 1rem;font-size:.75rem}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0d3a34,#165a52,#1f7a6b);padding:1rem}.login-card{background:linear-gradient(135deg,#fff,#f8fffe);padding:3rem;border-radius:1.5rem;box-shadow:0 20px 40px #0d3a3433;width:100%;max-width:400px;border:1px solid #e5f3f1;text-align:center}.login-logo{width:64px;height:auto;margin:0 auto 1.5rem;display:block}.login-title{background:linear-gradient(135deg,#0d3a34,#165a52);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.login-subtitle{color:#6b7280;margin-bottom:2rem;font-size:.875rem}.login-form{text-align:left}.login-form .form-group{margin-bottom:1.5rem}.login-form .btn{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600}.modal-overlay{position:fixed;inset:0;background:#0d3a3480;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:linear-gradient(135deg,#fff,#f8fffe);border-radius:1rem;padding:2rem;max-width:500px;width:100%;box-shadow:0 20px 40px #0d3a3433;border:1px solid #e5f3f1}.modal h2{margin-bottom:1rem;color:#0d3a34;font-weight:700}.modal p{margin-bottom:2rem;color:#4b5563;line-height:1.6}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;flex-wrap:wrap}.loading{display:flex;justify-content:center;align-items:center;min-height:200px}.spinner{width:40px;height:40px;border:4px solid #e5f3f1;border-top:4px solid #dcea2c;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#dc2626;padding:1rem;border-radius:.5rem;border:2px solid #fecaca;margin-bottom:1rem;font-weight:500}.success{background:linear-gradient(135deg,#dcea2c,#b8d01f);color:#0d3a34;padding:1rem;border-radius:.5rem;border:2px solid #a4c117;margin-bottom:1rem;font-weight:600}@media (max-width: 768px){.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.table{min-width:800px}.table th,.table td{padding:.5rem .375rem;font-size:.8rem}.user-cell{min-width:160px;gap:.5rem}.user-avatar-small,.user-avatar-placeholder-small{width:28px;height:28px}.table-text{max-width:100px}.table-actions{flex-direction:column;gap:.125rem}.btn-xs{padding:.25rem .375rem;font-size:.65rem}}@media (max-width: 480px){.table th,.table td{padding:.375rem .25rem;font-size:.75rem}.user-cell{min-width:140px}.table-text{max-width:80px}}@media (max-width: 768px){.header{padding:1rem;flex-direction:column;gap:1rem;text-align:center}.main-content{padding:1rem}.page-title{font-size:1.5rem}.filters{flex-direction:column;align-items:stretch}.filter-group{flex-direction:column;align-items:stretch;gap:.25rem}.search-input{width:100%}.form-grid{grid-template-columns:1fr;gap:1rem}.user-form{padding:1rem}.form-header{flex-direction:column;align-items:stretch;text-align:center}.form-actions,.action-buttons{flex-direction:column}.btn{justify-content:center}.modal{margin:1rem;padding:1.5rem}.modal-actions{flex-direction:column}}@media (max-width: 480px){.main-content{padding:.5rem}.user-form{padding:1rem}.form-grid{gap:.75rem}.user-card{padding:.75rem}.user-card-actions{flex-direction:column}.user-card-actions .btn{flex:none;width:100%}.user-field{flex-direction:column;align-items:flex-start;gap:.25rem}.field-value{text-align:left}}
