:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;color:#333}.App{min-height:100vh}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#666}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:border-color .25s}@keyframes pulse{0%{opacity:.6}to{opacity:1}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#8c1515,#b83a4b)}.login-card{background:#fff;border-radius:12px;padding:40px;box-shadow:0 10px 30px #0000001a;text-align:center;max-width:400px;width:100%}.login-card h1{color:#8c1515;margin-bottom:8px;font-size:28px;font-weight:700}.login-card h2{color:#666;margin-bottom:12px;font-size:18px;font-weight:500}.login-card>p{color:#777;margin-bottom:30px;font-size:16px;line-height:1.5}.login-content p{margin-bottom:16px;color:#555;font-size:14px;font-weight:600}.google-signin-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:14px 20px;border:2px solid #dadce0;border-radius:8px;background:#fff;color:#3c4043;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-bottom:12px}.google-signin-btn:hover{background-color:#f8f9fa;box-shadow:0 2px 8px #0000001a}.google-signin-btn:first-of-type{margin-bottom:12px}.google-signin-btn:last-of-type{margin-bottom:0}.google-icon{width:20px;height:20px}.login-footer{margin-top:30px;padding-top:20px;border-top:1px solid #eee}.login-footer p{color:#666;font-size:12px}.class-badge{display:inline-block;background:linear-gradient(135deg,#8c1515,#b83a4b);color:#fff;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.verification-container{min-height:100vh;padding:10px;background-color:#f8f9fa}.verification-card{max-width:900px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;overflow:hidden;min-height:calc(100vh - 20px);display:flex;flex-direction:column}.verification-header{background:#8c1515;color:#fff;padding:15px 20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;flex-shrink:0}.verification-header h1{font-size:20px;font-weight:700}.verification-content{padding:20px;flex:1;display:flex;flex-direction:column}.verification-content h2{color:#8c1515;margin-bottom:8px;font-size:18px;line-height:1.3}.verification-content>p{color:#666;margin-bottom:20px;line-height:1.5;font-size:14px}.names-list{flex:1;display:flex;flex-direction:column}.names-list h3{color:#8c1515;margin-bottom:15px;font-size:16px;font-weight:600}.names-verification-list{flex:1;overflow-y:auto;border:1px solid #e1e5e9;border-radius:8px;max-height:50vh}.name-verification-item{display:flex;align-items:center;justify-content:space-between;padding:12px 15px;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:all .2s ease;font-size:14px}.name-verification-item:last-child{border-bottom:none}.name-verification-item:hover:not(.disabled){background:#f8f9fa}.name-verification-item.disabled{opacity:.5;cursor:not-allowed;background:#f9f9f9}.select-btn{font-weight:600;font-size:12px;color:#fff;background:#8c1515;padding:4px 10px;border-radius:6px;transition:all .2s ease}.select-btn.taken{background:#6c757d;color:#fff}.name-verification-item:hover:not(.disabled) .select-btn:not(.taken){background:#a01a1a}.saving-indicator{text-align:center;padding:15px;color:#8c1515;font-weight:600;border-top:1px solid #e1e5e9;margin-top:15px}@media (max-width: 768px){.login-container{min-height:100vh;padding:20px 15px;align-items:flex-start;padding-top:15vh}.login-card{padding:30px 25px;max-width:380px;margin:0 auto}.login-card h1{font-size:24px;margin-bottom:6px}.login-card h2{font-size:16px;margin-bottom:10px}.login-card>p{font-size:14px;margin-bottom:25px;line-height:1.4}.google-signin-btn{padding:12px 18px;font-size:14px}.google-icon{width:18px;height:18px}}@media (max-width: 480px){.login-container{padding:15px 10px;padding-top:12vh}.login-card{padding:25px 20px;border-radius:8px}.login-card h1{font-size:22px}.login-card h2{font-size:15px}.login-card>p{font-size:13px;margin-bottom:20px}.google-signin-btn{padding:11px 16px;font-size:13px;gap:10px}}@media (max-height: 600px){.login-container{padding-top:8vh}}@media (max-height: 500px){.login-container{padding-top:5vh}}.dashboard-container{min-height:100vh;padding:10px;background-color:#f8f9fa}.dashboard-card{max-width:900px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;overflow:hidden;min-height:calc(100vh - 20px);display:flex;flex-direction:column}.dashboard-header{background:#8c1515;color:#fff;padding:15px 20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;flex-shrink:0}.dashboard-header h1{font-size:20px;font-weight:700}.user-info{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.user-info span{font-size:12px;opacity:.9}.logout-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:12px;transition:all .2s ease}.logout-btn:hover{background:#ffffff4d}.dashboard-content{padding:20px;flex:1;display:flex;flex-direction:column;gap:20px}.header-section{flex-shrink:0}.dashboard-content h2{color:#8c1515;margin-bottom:8px;font-size:18px}.dashboard-content>p{color:#666;margin-bottom:15px;line-height:1.5;font-size:14px}.submitted-notice{background:#d4edda;color:#155724;padding:10px 12px;border-radius:8px;border-left:4px solid #28a745;font-weight:500;margin-top:8px;font-size:14px}.user-details{display:flex;align-items:center;gap:10px}.profile-pic{width:32px;height:32px;border-radius:50%;border:2px solid rgba(255,255,255,.3)}.user-name{font-weight:600;font-size:12px}.user-email{font-size:10px;opacity:.8}.instructions{margin-bottom:15px}.instructions ol{padding-left:20px;margin:0}.instructions li{margin-bottom:8px;line-height:1.5;font-size:14px;color:#666}.instructions em{font-style:italic;color:#8c1515;font-weight:600}.class-indicator{margin-bottom:15px;text-align:center}.class-badge{display:inline-block;background:linear-gradient(135deg,#8c1515,#b83a4b);color:#fff;padding:8px 16px;border-radius:20px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #8c15154d}.crush-count-section{padding:15px;background:linear-gradient(135deg,#fff3cd,#ffeaa7);border-radius:8px;border-left:4px solid #f39c12;text-align:left;flex-shrink:0;margin-bottom:20px}.crush-count-section h2{color:#d68910;margin:0;font-size:18px;font-weight:400;font-style:italic}.matches-section{padding:15px;background:linear-gradient(135deg,#d4edda,#c3e6cb);border-radius:8px;border-left:4px solid #28a745;text-align:left;flex-shrink:0}.matches-section h2{color:#155724;margin-bottom:15px;font-size:18px;font-weight:400;font-style:italic}.matches-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-top:15px}.match-item{background:#fff;padding:15px;border-radius:8px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #28a745}.match-name{font-size:16px;font-weight:600;color:#155724;margin-bottom:6px}.match-email{font-size:12px;color:#6c757d;font-family:Courier New,monospace;word-break:break-all}.no-matches{margin-top:8px;padding:8px;background:#fff3cd;color:#856404;border-radius:6px;font-weight:500;font-size:13px}.selection-counter{display:inline-flex;align-items:center;gap:8px;background:#8c1515;color:#fff;padding:6px 12px;border-radius:20px;font-weight:600;font-size:13px;flex-shrink:0}.submitted-badge{background:#ffffff4d;padding:2px 6px;border-radius:12px;font-size:10px;font-weight:700}.updating-badge{background:#ffffff4d;padding:2px 6px;border-radius:12px;font-size:10px;font-weight:700;animation:pulse 1.5s ease-in-out infinite alternate}.unsaved-badge{background:#dc3545;padding:2px 6px;border-radius:12px;font-size:10px;font-weight:700;color:#fff;animation:pulse 1.5s ease-in-out infinite alternate}.locked-badge{background:#dc3545;padding:2px 6px;border-radius:12px;font-size:10px;font-weight:700;color:#fff}.selected-names{padding:15px;background:#f8f9fa;border-radius:8px;border-left:4px solid #8C1515;flex-shrink:0}.selected-names h3{color:#8c1515;margin-bottom:12px;font-size:14px;font-weight:600}.name-chips{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.name-chip{display:flex;align-items:center;justify-content:space-between;background:#8c1515;color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;font-weight:500;min-height:32px;width:100%;border:2px solid transparent;transition:all .2s ease}.name-chip.readonly{background:#6c757d;opacity:.8}.name-chip.locked{background:#8c1515;opacity:1;border:2px solid transparent}.name-chip span{flex:1;text-align:left;margin-right:6px}.remove-btn{background:#ffffff4d;color:#fff;border:none;width:20px;height:20px;border-radius:3px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;font-weight:700;flex-shrink:0}.remove-btn:hover{background:#ffffff80}.remove-btn:disabled{opacity:.5;cursor:not-allowed}.lock-icon{font-size:12px;opacity:.8;width:20px;height:20px;display:flex;align-items:right;justify-content:right;flex-shrink:0}.search-section{flex-shrink:0}.search-input{width:100%;padding:12px 40px 12px 15px;border:2px solid #e1e5e9;border-radius:8px;font-size:14px;transition:border-color .2s ease;box-sizing:border-box}.search-input:focus{outline:none;border-color:#8c1515}.search-input-container{position:relative;width:100%}.search-clear-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:18px;color:#666;cursor:pointer;padding:4px;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.search-clear-btn:hover{background:#f0f0f0;color:#333}.search-hint{text-align:center;padding:6px 12px;font-size:11px;color:#666;background:#f8f9fa;border-radius:4px;margin-top:8px;border-left:3px solid #8C1515}.available-names{flex:1;display:flex;flex-direction:column;min-height:0}.available-names h3{color:#8c1515;margin-bottom:15px;font-size:16px;font-weight:600;flex-shrink:0}.names-simple-list{flex:1;overflow-y:auto;border:1px solid #e1e5e9;border-radius:8px;background:#fff;min-height:400px;max-height:60vh;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;transform:translateZ(0);will-change:scroll-position;contain:layout style paint}.name-list-item{display:flex;align-items:center;justify-content:space-between;padding:12px 15px;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:all .2s ease;font-size:14px;height:48px;min-height:48px;box-sizing:border-box;contain:layout style paint}.name-list-item:last-child{border-bottom:none}.name-list-item:hover:not(.disabled){background:#f8f9fa}.name-list-item.disabled{opacity:.6;cursor:not-allowed;background:#f9f9f9}.name-text{flex:1;text-align:left;font-weight:500}.add-btn{font-weight:700;font-size:18px;color:#8c1515;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#8c15151a;transition:all .2s ease}.add-btn:hover{background:#8c151533;transform:scale(1.1)}.no-results{padding:20px;text-align:center;color:#666;font-style:italic;font-size:14px;line-height:1.4}.no-results small{display:block;margin:8px 0;color:#888;font-size:12px}.clear-search-link{background:none;border:none;color:#8c1515;text-decoration:underline;cursor:pointer;font-size:13px;margin-left:8px;padding:0;margin-top:8px;display:inline-block}.clear-search-link:hover{color:#a01a1a}.action-section{text-align:center;padding-top:15px;border-top:1px solid #e1e5e9;flex-shrink:0}.action-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.save-draft-btn,.submit-btn,.update-btn{padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;min-width:120px}.save-draft-btn{background:#6c757d;color:#fff}.save-draft-btn:hover:not(:disabled){background:#5a6268;transform:translateY(-1px);box-shadow:0 4px 12px #6c757d4d}.submit-btn,.update-btn{background:#8c1515;color:#fff;min-width:160px}.submit-btn:hover:not(:disabled),.update-btn:hover:not(:disabled){background:#a01a1a;transform:translateY(-1px);box-shadow:0 4px 12px #8c15154d}.save-draft-btn:disabled,.submit-btn:disabled,.update-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;background:#6c757d}.submitted-message{text-align:center;padding:20px 15px}.submitted-message h3{color:#28a745;margin-bottom:8px;font-size:16px}.submitted-message p{color:#666;font-size:14px;line-height:1.4}.search-highlight{background:#fff3cd;color:#856404;font-weight:600;padding:1px 2px;border-radius:2px}.search-loading{text-align:center;padding:8px;font-size:12px;color:#666;font-style:italic}@media (max-width: 768px){.dashboard-container{padding:5px}.dashboard-header{padding:12px 15px;flex-direction:column;align-items:flex-start;gap:8px}.user-info{width:100%;justify-content:space-between;gap:8px}.dashboard-content{padding:15px;gap:15px}.names-simple-list{max-height:60vh}.name-list-item{padding:14px 12px;font-size:13px;min-height:48px}.name-text{font-weight:500}.add-btn{width:28px;height:28px;font-size:20px}.user-details{flex-direction:row;align-items:center;gap:8px}.name-chips{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:6px}.name-chip{font-size:11px;padding:6px 10px;min-height:28px}.dashboard-content h2{font-size:16px}.action-buttons{flex-direction:column;align-items:center;gap:8px}.save-draft-btn,.submit-btn,.update-btn{width:100%;max-width:250px;padding:12px 16px}.submitted-message{padding:15px 10px}.matches-section{padding:12px}.matches-section h2{font-size:16px}.matches-list{grid-template-columns:1fr;gap:10px}.match-item{padding:12px}.match-name{font-size:14px}.selected-names{padding:12px}.crush-count-section{padding:12px;margin-bottom:15px}.crush-count-section h2{font-size:16px}.instructions ol{padding-left:16px}.instructions li{font-size:13px;margin-bottom:6px}.locked-badge{font-size:9px;padding:1px 4px}.lock-icon{font-size:10px}.search-input-container{margin-bottom:10px}.search-clear-btn{right:12px;width:28px;height:28px;font-size:20px}.search-hint{font-size:10px;padding:5px 8px}.names-simple-list{max-height:50vh;min-height:300px}.name-list-item{height:52px;min-height:52px;padding:14px 12px;font-size:13px}.no-results{padding:15px;font-size:13px}.no-results small{font-size:11px}}@media (max-width: 480px){.dashboard-card{border-radius:8px;min-height:calc(100vh - 10px)}.dashboard-container{padding:5px}.dashboard-header h1{font-size:18px}.dashboard-content h2{font-size:15px}.profile-pic{width:28px;height:28px}.user-name{font-size:11px}.user-email{font-size:9px}.selected-names{padding:10px}.search-input{padding:12px 15px;font-size:14px}.names-simple-list{max-height:65vh}.name-list-item{padding:16px 12px;font-size:14px;min-height:52px}.name-text{font-weight:500}.add-btn{width:32px;height:32px;font-size:22px}.name-chips{grid-template-columns:1fr;gap:6px}.name-chip{min-height:26px;font-size:10px}.action-buttons{gap:6px}.save-draft-btn,.submit-btn,.update-btn{padding:12px 16px;font-size:14px}.submitted-message h3{font-size:15px}.submitted-message p{font-size:13px}.matches-section h2,.crush-count-section h2{font-size:15px}.locked-badge{font-size:8px}.lock-icon{font-size:9px}.names-simple-list{max-height:45vh;min-height:280px}.name-list-item{height:56px;min-height:56px;padding:16px 12px;font-size:14px}.search-clear-btn{width:32px;height:32px;font-size:22px}.search-hint{font-size:9px;padding:4px 6px}}@media (hover: none) and (pointer: coarse){.names-simple-list{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.name-list-item{min-height:48px;padding:16px 15px}.name-list-item:active{background:#e9ecef;transform:scale(.98)}.add-btn:active{transform:scale(.9)}.search-clear-btn:active{transform:translateY(-50%) scale(.9)}}.names-simple-list{transform:translateZ(0);will-change:scroll-position}.name-list-item{contain:layout style paint}.header-actions{display:flex;align-items:center;gap:8px}.admin-toggle-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:12px;transition:all .2s ease}.admin-toggle-btn:hover{background:#ffffff4d}.admin-section{padding:20px 0}.admin-section h3{color:#8c1515;margin-bottom:20px;font-size:18px}.admin-header-section{margin-bottom:20px}.admin-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.admin-refresh-btn{background:#28a745;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease}.admin-refresh-btn:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.admin-refresh-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}.admin-nav{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.admin-nav-btn{background:#f8f9fa;color:#8c1515;border:2px solid #e1e5e9;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s ease;min-width:140px;text-align:center}.admin-nav-btn:hover:not(:disabled){background:#e9ecef;border-color:#8c1515}.admin-nav-btn:disabled{opacity:.6;cursor:not-allowed}.admin-nav-btn.active{background:#8c1515;color:#fff;border-color:#8c1515}.admin-access-denied{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:20px}.access-denied-card{background:#fff;padding:40px;border-radius:12px;box-shadow:0 10px 30px #0000001a;text-align:center;max-width:400px;width:100%;border-left:4px solid #dc3545}.access-denied-card h2{color:#dc3545;margin:0 0 15px;font-size:24px;font-weight:600}.access-denied-card p{color:#666;margin:10px 0;font-size:14px;line-height:1.5}.access-denied-card p:last-child{margin-bottom:0;font-weight:500}.admin-loading{display:flex;justify-content:center;align-items:center;padding:40px;color:#666;font-style:italic}.admin-loading:after{content:"...";animation:loading-dots 1.5s infinite}@keyframes loading-dots{0%,20%{opacity:0}50%{opacity:1}to{opacity:0}}.admin-nav-btn:focus,.admin-refresh-btn:focus{outline:2px solid #8C1515;outline-offset:2px}@media (prefers-reduced-motion: reduce){.admin-refresh-btn:hover:not(:disabled){transform:none}}@media (prefers-contrast: high){.admin-nav-btn,.admin-refresh-btn{border:2px solid #000}.admin-nav .admin-nav-btn.active{border:3px solid #000}}.admin-class-nav{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.admin-class-btn{background:linear-gradient(135deg,#8c1515,#b83a4b);color:#fff;border:2px solid transparent;padding:12px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;min-width:180px;text-align:center;box-shadow:0 2px 4px #8c15154d}.admin-class-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #8c151566}.admin-class-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.admin-class-btn.active{background:linear-gradient(135deg,#28a745,#20c997);box-shadow:0 4px 8px #28a74566}.admin-class-header{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:20px;border-radius:8px;border-left:4px solid #8C1515;margin-bottom:20px}.admin-class-header h4{color:#8c1515;margin:0 0 15px;font-size:18px;font-weight:600}.admin-class-stats-summary{display:flex;gap:20px;flex-wrap:wrap}.class-stat{display:flex;flex-direction:column;align-items:center;text-align:center;font-size:13px;color:#666}.class-stat strong{color:#8c1515;font-size:16px;font-weight:700}.admin-class-users-header{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:15px 20px;border-radius:8px;border-left:4px solid #8C1515;margin-bottom:15px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.admin-class-users-header h4{color:#8c1515;margin:0;font-size:16px;font-weight:600}.admin-class-users-summary{display:flex;gap:15px;flex-wrap:wrap;font-size:12px;color:#666}.admin-class-users-summary span{background:#fff;padding:4px 8px;border-radius:4px;border:1px solid #e1e5e9;font-weight:500}.admin-definitions{margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:8px;border-left:4px solid #8C1515}.admin-definitions p{margin:8px 0;font-size:13px;color:#333;line-height:1.4}.admin-definitions strong{color:#8c1515;font-weight:600}.admin-overview{display:flex;flex-direction:column;gap:20px}.admin-quick-insights{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:15px;margin-bottom:20px}.admin-insight-card{background:#fff;padding:20px;border-radius:8px;border-left:4px solid #8C1515;box-shadow:0 2px 4px #0000001a;transition:transform .2s ease}.admin-insight-card:hover{transform:translateY(-2px)}.admin-insight-card h4{color:#8c1515;margin:0 0 12px;font-size:14px;font-weight:600}.admin-insight-card p{margin:6px 0;font-size:13px;color:#666}.admin-analytics{display:flex;flex-direction:column;gap:20px}.admin-analytics-section{background:#fff;padding:20px;border-radius:8px;border-left:4px solid #8C1515;box-shadow:0 2px 4px #0000001a}.admin-analytics-section h4{color:#8c1515;margin:0 0 15px;font-size:16px}.admin-analytics-section:first-child{border-left-color:#28a745}.admin-analytics-section:first-child h4{color:#28a745}.admin-matches-list{max-height:300px;overflow-y:auto;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.admin-match-item{padding:8px 12px;margin-bottom:4px;background:#f8f9fa;border-radius:4px;font-size:13px;border-left:3px solid #28a745}.admin-list{max-height:300px;overflow-y:auto;-webkit-overflow-scrolling:touch}.admin-list-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;margin-bottom:4px;background:#f8f9fa;border-radius:4px;font-size:13px;border-left:3px solid #8C1515}.admin-inactive-item{padding:12px;margin-bottom:8px;background:#fff3cd;border-radius:4px;border-left:3px solid #ffc107}.admin-inactive-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;margin-bottom:8px}.admin-inactive-details p{margin:4px 0;font-size:12px;color:#666}.admin-search-section{margin-bottom:15px}.admin-search-input{width:100%;padding:12px 40px 12px 15px;border:2px solid #e1e5e9;border-radius:8px;font-size:14px;transition:border-color .2s ease;box-sizing:border-box}.admin-search-input:focus{outline:none;border-color:#8c1515}.admin-search-input-container{position:relative;width:100%;margin-bottom:8px}.admin-search-clear-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:18px;color:#666;cursor:pointer;padding:4px;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.admin-search-clear-btn:hover{background:#f0f0f0;color:#333}.admin-search-hint{text-align:center;padding:6px 12px;font-size:10px;color:#666;background:#f8f9fa;border-radius:4px;margin-bottom:8px;border-left:3px solid #8C1515}.admin-pagination-info{margin-top:8px;font-size:12px;color:#666;text-align:center;font-style:italic}.admin-users-container{max-height:70vh;overflow-y:auto;border:1px solid #e1e5e9;border-radius:8px;background:#fff;-webkit-overflow-scrolling:touch;scroll-behavior:auto!important}.virtual-spacer{background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.02) 50%,transparent 100%);pointer-events:none}.admin-user-item{border-bottom:1px solid #f0f0f0;background:#fff}.admin-user-item:last-child{border-bottom:none}.admin-user-header{padding:15px;display:flex;justify-content:space-between;align-items:center;background:#fff;transition:background-color .2s ease;min-height:80px;box-sizing:border-box}.admin-user-header:hover{background:#f8f9fa}.admin-user-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.admin-user-name{font-weight:600;color:#8c1515;margin:0;font-size:14px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;line-height:1.3}.user-type-label{color:#6c757d;font-size:11px;font-weight:400}.no-name-indicator{color:#dc3545;font-size:11px;font-weight:400}.discrepancy-indicator{color:#dc3545;font-size:11px}.admin-user-email{font-size:12px;color:#666;margin:0;word-break:break-word;line-height:1.3}.admin-user-stats{font-size:11px;color:#888;display:flex;align-items:center;gap:4px;flex-wrap:wrap;margin:0;line-height:1.3}.admin-view-btn{background:#8c1515;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s ease;min-width:80px;flex-shrink:0;height:36px;display:flex;align-items:center;justify-content:center}.admin-view-btn:hover:not(:disabled){background:#a01a1a;transform:translateY(-1px)}.admin-view-btn:disabled{opacity:.5;cursor:not-allowed;background:#6c757d;transform:none}.admin-user-expanded{padding:20px;background:#f8f9fa;border-top:1px solid #e1e5e9;overflow:visible}.admin-view-header{margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #8C1515}.admin-view-header h4{color:#8c1515;margin:0;font-size:16px}.admin-data-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;width:100%;box-sizing:border-box;min-height:auto}.admin-data-card{background:#fff;padding:20px;border-radius:8px;border-left:4px solid #8C1515;box-shadow:0 2px 4px #0000001a;transition:transform .2s ease;display:flex;flex-direction:column;box-sizing:border-box}.admin-data-card:hover{transform:translateY(-2px)}.admin-data-number{font-size:32px;font-weight:700;color:#8c1515;margin-bottom:5px;line-height:1}.admin-data-label{font-size:14px;color:#666;font-weight:600;margin-bottom:15px;text-transform:uppercase;letter-spacing:.5px;line-height:1.2}.admin-data-names{max-height:150px;overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1}.admin-name-item{padding:6px 10px;margin-bottom:4px;background:#f8f9fa;border-radius:4px;font-size:12px;border-left:3px solid #e1e5e9;transition:background-color .2s ease;line-height:1.3}.admin-name-item:hover{background:#e9ecef}.admin-name-item.locked{background:#fff3cd;border-left-color:#ffc107;font-weight:600}.admin-match-with-timestamp{display:flex;flex-direction:column;gap:2px;padding:8px 10px;box-sizing:border-box}.admin-match-name{font-size:12px;font-weight:600;color:#333;line-height:1.3}.admin-match-timestamp{font-size:10px;color:#28a745;font-style:italic;font-weight:500;line-height:1.2}.admin-discrepancy{margin-top:10px;padding:8px;background:#f8d7da;color:#721c24;border-radius:4px;font-size:11px;font-weight:600}.admin-no-activity{text-align:center;padding:40px 20px;color:#666;background:#fff;border-radius:8px;font-style:italic}.admin-controls{margin-bottom:20px}.admin-filter-section{margin-top:10px}.admin-filter-dropdown{width:100%;padding:10px 12px;border:2px solid #e1e5e9;border-radius:8px;font-size:14px;background:#fff;color:#333;cursor:pointer;transition:border-color .2s ease}.admin-filter-dropdown:focus{outline:none;border-color:#8c1515}.admin-filter-dropdown:hover{border-color:#999}.admin-user-ghost{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-left:4px solid #6c757d;opacity:.9}.admin-user-ghost .admin-user-header{background:linear-gradient(135deg,#f1f3f4,#e8eaed)}.admin-user-ghost .admin-user-name{font-style:italic}.admin-user-ghost .admin-view-btn{background:#6c757d;cursor:not-allowed}.admin-user-ghost .admin-view-btn:hover{background:#6c757d;transform:none}.admin-user-inactive{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border-left:4px solid #ffc107;opacity:.9}.admin-user-inactive .admin-user-header{background:linear-gradient(135deg,#fff8e1,#ffecb3)}.admin-user-inactive .admin-user-name{font-style:italic;color:#856404}.no-results{padding:15px;text-align:center;color:#666;font-style:italic;font-size:13px}.admin-clear-search-link{background:none;border:none;color:#8c1515;text-decoration:underline;cursor:pointer;font-size:12px;margin-left:8px;padding:0;margin-top:8px;display:inline-block}.admin-clear-search-link:hover{color:#a01a1a}.admin-search-highlight{background:#fff3cd;color:#856404;font-weight:600;padding:1px 2px;border-radius:2px}.admin-match-item-with-timestamp{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;margin-bottom:6px;background:#f8f9fa;border-radius:4px;font-size:13px;border-left:3px solid #28a745;transition:background-color .2s ease}.admin-match-item-with-timestamp:hover{background:#e9ecef}.admin-match-pair{font-weight:600;color:#333;flex:1}.admin-match-time{font-size:11px;color:#28a745;font-style:italic;font-weight:500;margin-left:10px;white-space:nowrap}@media (max-width: 768px){.admin-data-grid{grid-template-columns:1fr;gap:12px}.admin-user-header{flex-direction:column;align-items:flex-start;gap:10px;padding:12px;min-height:90px}.admin-user-info{width:100%}.admin-view-btn{align-self:flex-end;width:auto}.admin-data-card{padding:15px}.admin-data-number{font-size:28px}.admin-data-label{font-size:12px}.admin-user-expanded{padding:15px}.admin-match-item-with-timestamp{flex-direction:column;align-items:flex-start;gap:4px}.admin-match-time{margin-left:0;font-size:10px}}@media (max-width: 480px){.admin-user-header{padding:12px;min-height:100px}.admin-user-name{font-size:12px}.admin-user-email{font-size:11px;word-break:break-all}.admin-user-stats{font-size:10px;flex-direction:column;align-items:flex-start;gap:2px}.admin-view-btn{font-size:11px;padding:6px 12px;min-width:70px;height:32px}.admin-data-card{padding:12px}.admin-data-number{font-size:24px}.admin-data-label{font-size:11px;margin-bottom:10px}.admin-name-item{font-size:11px;padding:4px 8px}.admin-match-item-with-timestamp{padding:8px 10px}.admin-match-pair{font-size:12px}.admin-match-time{font-size:9px}}@media (max-width: 768px){.admin-access-denied{min-height:50vh;padding:15px}.access-denied-card{padding:30px 20px}.access-denied-card h2{font-size:20px}.access-denied-card p{font-size:13px}.header-actions{flex-direction:row;gap:6px}.admin-toggle-btn,.admin-refresh-btn{font-size:11px;padding:5px 8px}.admin-title-row{flex-direction:column;align-items:flex-start;gap:10px}.admin-class-nav{flex-direction:column;gap:8px}.admin-class-btn{width:100%;min-width:auto;padding:10px 16px;font-size:13px}.admin-class-header{padding:15px}.admin-class-header h4{font-size:16px}.admin-class-stats-summary{gap:15px;justify-content:space-around}.class-stat{font-size:12px}.class-stat strong{font-size:14px}.admin-class-users-header{flex-direction:column;align-items:flex-start;gap:8px;padding:12px 15px}.admin-class-users-header h4{font-size:14px}.admin-class-users-summary{gap:10px;font-size:11px}.admin-definitions{padding:12px}.admin-definitions p{font-size:12px;margin:6px 0}.admin-nav{gap:6px;flex-direction:column}.admin-nav-btn{font-size:12px;padding:8px 12px;width:100%;text-align:center;min-width:auto}.admin-quick-insights{grid-template-columns:1fr;gap:12px}.admin-insight-card{padding:15px}.admin-data-grid{grid-template-columns:1fr;gap:12px}.admin-data-card{padding:15px}.admin-data-number{font-size:28px}.admin-data-label{font-size:12px}.admin-user-expanded{padding:15px}.admin-user-header{flex-direction:column;align-items:flex-start;gap:10px;padding:12px}.admin-user-info{width:100%}.admin-user-name{font-size:13px;flex-wrap:wrap;gap:4px}.admin-view-btn{align-self:flex-end;width:auto}.admin-filter-dropdown{padding:8px 10px;font-size:13px}.admin-users-container{max-height:60vh}.user-type-label,.no-name-indicator,.discrepancy-indicator{font-size:10px}.admin-pagination-info{font-size:11px}.admin-search-clear-btn{right:12px;width:28px;height:28px;font-size:20px}.admin-search-hint{font-size:9px;padding:5px 8px}.admin-search-input{padding:10px 35px 10px 12px;font-size:13px}.admin-users .no-results{padding:15px;font-size:13px}.admin-users .no-results small{font-size:11px}}@media (max-width: 480px){.header-actions{width:100%;justify-content:space-between}.admin-toggle-btn,.admin-refresh-btn{font-size:10px;padding:4px 6px}.admin-title-row h3{font-size:16px}.admin-class-btn{padding:8px 12px;font-size:12px}.admin-class-header{padding:12px}.admin-class-header h4{font-size:15px}.admin-class-stats-summary{gap:10px}.class-stat{font-size:11px}.class-stat strong{font-size:13px}.admin-class-users-header{padding:10px 12px}.admin-class-users-header h4{font-size:13px}.admin-class-users-summary{gap:8px;font-size:10px}.admin-definitions{padding:10px}.admin-definitions p{font-size:11px;margin:5px 0}.admin-nav{flex-direction:column;gap:4px}.admin-nav-btn{width:100%;text-align:center;padding:10px 12px;font-size:13px}.admin-search-input{padding:8px 38px 8px 10px;font-size:12px}.admin-user-header{padding:12px}.admin-user-name{font-size:12px}.admin-user-email{font-size:11px;word-break:break-all}.admin-user-stats{font-size:10px;flex-direction:column;align-items:flex-start;gap:2px}.admin-view-btn{font-size:11px;padding:6px 12px;min-width:70px}.admin-data-card{padding:12px}.admin-data-number{font-size:24px}.admin-data-label{font-size:11px;margin-bottom:10px}.admin-name-item{font-size:11px;padding:4px 8px}.admin-filter-dropdown{padding:6px 8px;font-size:12px}.admin-list-item,.admin-inactive-header{flex-direction:column;align-items:flex-start;gap:4px}.admin-users-container{max-height:55vh}.user-type-label,.no-name-indicator,.discrepancy-indicator{font-size:9px}.admin-pagination-info{font-size:10px}.admin-user-item{min-height:90px}.admin-view-btn{min-height:36px;min-width:80px}.admin-class-btn{min-height:44px}.admin-search-clear-btn{width:32px;height:32px;font-size:22px}.admin-search-hint{font-size:8px;padding:4px 6px}}@media (hover: none) and (pointer: coarse){.admin-users-container{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.admin-user-header:active{background:#e9ecef}.admin-view-btn:active,.admin-data-card:active,.admin-class-btn:active{transform:scale(.98)}.admin-search-clear-btn:active{transform:translateY(-50%) scale(.9)}}@media (prefers-reduced-motion: reduce){.admin-user-expanded{animation:none}.admin-data-card:hover,.admin-insight-card:hover{transform:none}.admin-view-btn:hover:not(:disabled),.admin-refresh-btn:hover:not(:disabled),.admin-class-btn:hover:not(:disabled){transform:none}}@media (prefers-contrast: high){.admin-user-item,.admin-view-btn,.admin-class-btn,.admin-refresh-btn{border:2px solid #000}.admin-class-nav .admin-class-btn.active{border:3px solid #000}}.admin-class-btn:focus,.admin-view-btn:focus{outline:2px solid #8C1515;outline-offset:2px}.admin-search-input:focus,.admin-filter-dropdown:focus{box-shadow:0 0 0 3px #8c151533}
