:root{--primary-color:#1e4dff;--primary-hover:#1640d6;--primary-light:#def;--primary-bg:#1e4dff14;--primary-gradient-start:#1e4dff;--primary-gradient-end:#5f8cff;--primary-shadow:#1e4dff59;--primary-contrast:#fff;--accent-gold:#e8c96b;--accent-gold-dark:#c9a84c;--accent-gold-bg:#e8c96b26;--bg-color:#f6f2ee;--bg-gradient:linear-gradient(135deg, #f6f2ee 0%, #eef2f8 100%);--card-bg:#ffffffd9;--sidebar-bg:#fff9;--header-bg:#ffffffb8;--text-dark:#1d1d1f;--text-muted:#6e6e73;--text-light:#aeaeb2;--border-color:#e5e5eab3;--card-shadow:0 8px 28px -8px #1e4dff12, 0 2px 6px 0 #00000008;--card-shadow-hover:0 18px 40px -12px #1e4dff24, 0 4px 12px -2px #1e4dff0f;--success:#10b981;--success-bg:#10b9811a;--danger:#ef4444;--danger-bg:#ef44441a;--info:#5f8cff;--info-bg:#5f8cff1a;--font-title:"Outfit", sans-serif;--font-body:"Inter", sans-serif;--sidebar-width:260px;--sidebar-collapsed-width:70px;--header-height:70px;--transition-fast:.15s ease;--transition-normal:.25s cubic-bezier(.4, 0, .2, 1)}:root[data-theme=classic]{--primary-color:#1e4dff;--primary-hover:#1640d6;--primary-light:#def;--primary-bg:#eef3ff;--primary-gradient-start:#1e4dff;--primary-gradient-end:#5f8cff;--primary-shadow:#1e4dff26;--primary-contrast:#fff;--accent-gold:#e8c96b;--accent-gold-dark:#c9a84c;--accent-gold-bg:#e8c96b1f;--bg-color:#f6f2ee;--bg-gradient:none;--card-bg:#fffffff2;--sidebar-bg:#fff;--header-bg:#ffffffeb;--text-dark:#1d1d1f;--text-muted:#6e6e73;--text-light:#aeaeb2;--border-color:#e5e5eae6;--card-shadow:0 4px 20px -2px #0000000d, 0 2px 8px -1px #00000005;--card-shadow-hover:0 12px 28px -4px #1e4dff14, 0 4px 12px -2px #00000008;--info:#5f8cff;--info-bg:#5f8cff1a;--success-bg:#ecfdf5;--danger-bg:#fef2f2}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg-gradient,var(--bg-color));background-color:var(--bg-color);color:var(--text-dark);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-attachment:fixed;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-title);letter-spacing:-.02em;font-weight:600}.app-container{width:100%;min-height:100vh;display:block}.main-content{margin-left:var(--sidebar-width);height:100vh;padding:24px;padding-top:calc(var(--header-height) + 24px);transition:margin-left var(--transition-normal);box-sizing:border-box;flex-direction:column;display:flex;overflow:hidden}.main-content-collapsed{margin-left:var(--sidebar-collapsed-width,70px)}.main-content>div{flex:1;min-height:0;overflow-y:auto}@media (width<=768px){.main-content,.main-content-collapsed{margin-left:0}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.glass-card{background:var(--card-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color);box-shadow:var(--card-shadow);transition:transform var(--transition-normal), box-shadow var(--transition-normal), background var(--transition-normal);border-radius:20px}.glass-card-interactive:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-2px)}.btn{font-family:var(--font-title);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:.95rem;font-weight:600;display:inline-flex}.btn-primary{background-color:var(--primary-color);color:var(--primary-contrast,#fff)}.btn-primary:hover{background-color:var(--primary-hover);color:var(--primary-contrast,#fff);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{color:var(--text-dark);border:1px solid var(--border-color);background-color:#fff}.btn-secondary:hover{background-color:#f9fafb;border-color:#d1d5db}.btn-danger{background-color:var(--danger-bg);color:var(--danger)}.btn-danger:hover{background-color:#fee2e2}.form-group{flex-direction:column;gap:6px;margin-bottom:20px;display:flex}.form-label{font-family:var(--font-title);color:var(--text-dark);font-size:.9rem;font-weight:600}.form-input,.form-select,.form-textarea{border:1px solid var(--border-color);width:100%;font-family:var(--font-body);color:var(--text-dark);transition:all var(--transition-fast);background-color:#fff;border-radius:10px;padding:10px 14px;font-size:.95rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #1e4dff1f}.badge{font-size:.8rem;font-weight:600;font-family:var(--font-title);text-transform:capitalize;border-radius:9999px;align-items:center;padding:4px 10px;display:inline-flex}.badge-success{background-color:var(--success-bg);color:var(--success)}.badge-danger{background-color:var(--danger-bg);color:var(--danger)}.badge-info{background-color:var(--info-bg);color:var(--info)}.badge-warning{background-color:var(--primary-bg);color:var(--primary-hover)}.table-container{width:100%;overflow-x:auto}.custom-table{border-collapse:collapse;text-align:left;width:100%}.custom-table th{border-bottom:1px solid var(--border-color);color:var(--text-muted);font-family:var(--font-title);background-color:#f3f4f699;padding:14px 16px;font-size:.9rem;font-weight:600}.custom-table td{border-bottom:1px solid var(--border-color);color:var(--text-dark);padding:14px 16px;font-size:.95rem}.custom-table tr:last-child td{border-bottom:none}.custom-table tr:hover td{background-color:#f9fafb80}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-fade-in{animation:.3s cubic-bezier(.16,1,.3,1) forwards fadeIn}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background-color:#0f172a66;justify-content:center;align-items:flex-start;padding:40px 20px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-content{width:100%;max-width:550px;margin:auto;padding:28px;animation:.25s cubic-bezier(.16,1,.3,1) forwards fadeIn}@media (width<=576px){.modal-overlay{padding:16px 10px}.modal-content{padding:20px 16px}.modal-form-row,.form-grid-2{grid-template-columns:1fr!important;gap:12px!important}.btn{width:100%}.modal-actions{flex-direction:column-reverse;gap:8px}.modal-actions .btn{margin:0}}.sidebar{width:var(--sidebar-width);background-color:var(--sidebar-bg);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--border-color);z-index:100;height:100vh;transition:width var(--transition-normal), transform var(--transition-normal), background-color var(--transition-normal), border-color var(--transition-normal);flex-direction:column;padding:24px 16px;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.sidebar-logo-container{transition:gap var(--transition-normal), padding var(--transition-normal), justify-content var(--transition-normal);align-items:center;gap:12px;margin-bottom:30px;padding:0 8px;display:flex}.sidebar-logo-icon{font-size:24px}.sidebar-logo-img{object-fit:contain;border-radius:6px;width:32px;height:32px}.sidebar-logo-full-img{object-fit:contain;object-position:left center;width:100%;max-width:190px;height:44px}.sidebar-logo-icon-img{object-fit:cover;object-position:left center;width:42px;height:42px}.sidebar-logo-text{font-family:var(--font-title);color:var(--text-dark);letter-spacing:-.03em;white-space:nowrap;text-overflow:ellipsis;font-size:1.15rem;font-weight:800;overflow:hidden}.sidebar-user-card{border:1px solid var(--border-color);transition:padding var(--transition-normal), margin var(--transition-normal), gap var(--transition-normal), background-color var(--transition-normal), border-color var(--transition-normal);background-color:#fff6;border-radius:12px;align-items:center;gap:12px;margin-bottom:24px;padding:12px;display:flex}.sidebar-user-avatar{background-color:var(--primary-light);width:40px;height:40px;color:var(--primary-hover);font-family:var(--font-title);border-radius:10px;justify-content:center;align-items:center;font-size:1.1rem;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-family:var(--font-title);color:var(--text-dark);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.sidebar-user-role-badge{color:var(--text-muted);text-transform:capitalize;margin-top:2px;font-size:.75rem;font-weight:600;display:inline-block}.sidebar-nav{flex-direction:column;flex:1;gap:6px;display:flex}.sidebar-link{color:var(--text-muted);font-family:var(--font-title);transition:background-color var(--transition-fast), color var(--transition-fast), padding var(--transition-normal), gap var(--transition-normal), justify-content var(--transition-normal);border-radius:10px;align-items:center;gap:12px;padding:10px 14px;font-size:.95rem;font-weight:500;text-decoration:none;display:flex}.sidebar-link:hover{color:var(--text-dark);background-color:#1f29370d}.sidebar-link-active{box-shadow:0 8px 16px -4px var(--primary-shadow);font-weight:600;color:#fff!important;background:linear-gradient(135deg, var(--primary-gradient-start), var(--primary-gradient-end))!important}.sidebar-link-active svg{color:#fff!important}.sidebar-logout-btn{color:var(--danger);font-family:var(--font-title);cursor:pointer;text-align:left;width:100%;transition:background-color var(--transition-fast), color var(--transition-fast), padding var(--transition-normal), gap var(--transition-normal), justify-content var(--transition-normal);background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;margin-top:auto;padding:10px 14px;font-size:.95rem;font-weight:600;display:flex}.sidebar-logout-btn:hover{background-color:var(--danger-bg)}.sidebar-collapsed{width:var(--sidebar-collapsed-width,70px)}.sidebar-collapsed .sidebar-logo-container{justify-content:center;gap:0;padding:0}.sidebar-collapsed .sidebar-logo-text{display:none}.sidebar-collapsed .sidebar-user-card{background-color:#0000;border-color:#0000;justify-content:center;gap:0;padding:8px 0}.sidebar-collapsed .sidebar-user-info{display:none}.sidebar-collapsed .sidebar-link{justify-content:center;gap:0;padding:10px 0}.sidebar-collapsed .sidebar-link span{display:none}.sidebar-collapsed .sidebar-logout-btn{justify-content:center;gap:0;padding:10px 0}.sidebar-collapsed .sidebar-logout-btn span{display:none}.sidebar-mobile-backdrop{-webkit-backdrop-filter:blur(4px);z-index:95;width:100vw;height:100vh;animation:fadeIn var(--transition-normal) forwards;background-color:#0f172a66;position:fixed;top:0;left:0}@media (width<=768px){.sidebar{box-shadow:none;background-color:#fff;left:0;transform:translate(-100%);width:var(--sidebar-width)!important}.sidebar.sidebar-mobile-open{transform:translate(0);box-shadow:10px 0 30px #0f172a26}.sidebar.sidebar-mobile-open.sidebar-collapsed{width:var(--sidebar-width)!important}.sidebar.sidebar-mobile-open.sidebar-collapsed .sidebar-logo-container{justify-content:flex-start;gap:12px;padding:0 8px}.sidebar.sidebar-mobile-open.sidebar-collapsed .sidebar-logo-text{display:inline}.sidebar.sidebar-mobile-open.sidebar-collapsed .sidebar-logo-full-img{width:100%;max-width:190px;height:44px}.sidebar.sidebar-mobile-open.sidebar-collapsed .sidebar-logo-icon-img{object-position:left center;width:100%;max-width:190px;height:44px}.sidebar.sidebar-mobile-open.sidebar-collapsed .sidebar-user-card{border:1px solid var(--border-color);background-color:#fff6;justify-content:flex-start;gap:12px;padding:12px}.sidebar.sidebar-mobile-open.sidebar-collapsed .sidebar-user-info{display:block}.sidebar.sidebar-mobile-open.sidebar-collapsed .sidebar-link{justify-content:flex-start;gap:12px;padding:10px 14px}.sidebar.sidebar-mobile-open.sidebar-collapsed .sidebar-link span{display:inline}.sidebar.sidebar-mobile-open.sidebar-collapsed .sidebar-logout-btn{justify-content:flex-start;gap:12px;padding:10px 14px}.sidebar.sidebar-mobile-open.sidebar-collapsed .sidebar-logout-btn span{display:inline}}.header{height:var(--header-height);width:calc(100% - var(--sidebar-width));background-color:var(--header-bg);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);z-index:90;transition:width var(--transition-normal), background-color var(--transition-normal), border-color var(--transition-normal), left var(--transition-normal);justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:fixed;top:0;right:0}.sidebar-collapsed-layout .header{width:calc(100% - var(--sidebar-collapsed-width,70px))}.header-left{align-items:center;display:flex}.sidebar-toggle-btn{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;margin-right:12px;padding:8px;display:flex}.sidebar-toggle-btn:hover{color:var(--primary-color);background-color:#1f293714;transform:scale(1.05)}.sidebar-toggle-btn:active{transform:scale(.95)}.header-title{color:var(--text-dark);font-size:1.35rem;font-family:var(--font-title);letter-spacing:-.02em;font-weight:700}.header-right{align-items:center;gap:20px;display:flex}.header-search{align-items:center;display:flex;position:relative}.search-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:12px}.search-input{border:1px solid var(--border-color);font-family:var(--font-body);width:240px;color:var(--text-dark);transition:all var(--transition-fast);background-color:#ffffff80;border-radius:9999px;padding:10px 16px 10px 40px;font-size:.88rem}.search-input:focus{border-color:var(--primary-color);width:290px;box-shadow:0 0 0 4px var(--primary-bg);background-color:#fffffff2;outline:none}.header-icon-btn{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;display:flex;position:relative}.header-icon-btn:hover{color:var(--text-dark);background-color:#f1f5f9}.bell-badge{background-color:var(--danger);border:1.5px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px}.header-user-profile{border-left:1px solid var(--border-color);align-items:center;gap:12px;padding-left:16px;display:flex}.header-user-text{text-align:right;flex-direction:column;display:flex}.header-user-name{font-family:var(--font-title);color:var(--text-dark);font-size:.88rem;font-weight:600}.header-user-role{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:1px;font-size:.72rem;font-weight:600}.header-user-avatar-icon{width:36px;height:36px;color:var(--text-muted);border:1px solid var(--border-color);background-color:#f1f5f9;border-radius:50%;justify-content:center;align-items:center;display:flex}@media (width<=768px){.header,.sidebar-collapsed-layout .header{background-color:#fff;padding:0 16px;width:100%!important}.header-search,.header-user-text{display:none}.header-user-profile{border-left:none;padding-left:0}.header-right{gap:12px}.header-title{font-size:1.15rem}}.login-page{background:var(--bg-gradient,var(--bg-color));background-color:var(--bg-color);width:100%;min-height:100vh;display:flex}.login-banner{color:#fff;background:linear-gradient(145deg,#0a1628 0%,#0d1e3d 50%,#091530 100%);flex:1.2;justify-content:center;align-items:center;padding:40px;display:flex;position:relative;overflow:hidden}.login-banner:before{content:"";opacity:.12;filter:blur(90px);background-color:#1e4dff;border-radius:50%;width:380px;height:380px;position:absolute;top:-120px;left:-120px}.login-banner:after{content:"";opacity:.08;filter:blur(70px);background-color:#e8c96b;border-radius:50%;width:280px;height:280px;position:absolute;bottom:-60px;right:-60px}.login-banner-content{text-align:left;z-index:10;max-width:480px}.banner-logo-svg{margin-bottom:32px}.banner-logo-img{object-fit:contain;filter:drop-shadow(0 0 20px #1e4dff80)drop-shadow(0 0 8px #e8c96b4d);width:100%;max-width:340px;height:auto}.login-banner-content p{color:#ffffff8c;margin-top:12px;font-size:1.1rem;font-weight:400;line-height:1.6}.login-form-container{flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.login-form{width:100%;max-width:420px;padding:36px}.login-form-header{text-align:left;margin-bottom:28px}.login-form-header h2{font-size:1.75rem;font-family:var(--font-title);color:var(--text-dark);font-weight:700}.login-form-header p{color:var(--text-muted);margin-top:6px;font-size:.9rem}.input-with-icon{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-light);pointer-events:none;position:absolute;left:14px}.input-with-icon .form-input{padding-left:42px}.login-error-alert{background-color:var(--danger-bg);color:var(--danger);border:1px solid #ef444426;border-radius:10px;margin-bottom:20px;padding:12px;font-size:.88rem;font-weight:500}.login-submit-btn{width:100%;margin-top:10px;padding:12px;font-size:1rem}.login-form-footer{text-align:center;color:var(--text-muted);flex-direction:column;gap:6px;margin-top:24px;font-size:.88rem;display:flex}.register-link{color:var(--primary-hover);font-weight:600;text-decoration:none}.register-link:hover{text-decoration:underline}@media (width<=900px){.login-page{flex-direction:column}.login-banner{display:none}.login-form-container{padding:24px}}.register-page{background-color:var(--bg-color);justify-content:center;align-items:center;width:100%;min-height:100vh;padding:40px 20px;display:flex}.register-container{flex-direction:column;gap:24px;width:100%;max-width:800px;display:flex}.register-header{text-align:left}.back-link{color:var(--text-muted);font-family:var(--font-title);transition:color var(--transition-fast);align-items:center;gap:6px;margin-bottom:12px;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex}.back-link:hover{color:var(--text-dark)}.register-header h2{font-size:1.85rem;font-family:var(--font-title);color:var(--text-dark);font-weight:8500}.register-header p{color:var(--text-muted);margin-top:4px;font-size:.95rem}.register-form{padding:32px}.register-grid{grid-template-columns:1fr 1.2fr;gap:32px;margin-bottom:20px;display:grid}.register-section{flex-direction:column;display:flex}.register-section h3{font-size:1.05rem;font-family:var(--font-title);color:var(--text-dark);border-bottom:1.5px solid var(--border-color);margin-bottom:18px;padding-bottom:8px;font-weight:700}.text-area-group{margin-top:10px}.register-submit-btn{width:100%;margin-top:10px;padding:12px;font-size:1rem}.register-alert{border:1px solid #0000;border-radius:10px;padding:14px;font-size:.92rem;font-weight:500}.alert-danger{background-color:var(--danger-bg);color:var(--danger);border-color:#ef444426}.alert-success{background-color:var(--success-bg);color:var(--success);border-color:#10b98126}@media (width<=768px){.register-grid{grid-template-columns:1fr;gap:20px}}.dashboard-page{flex-direction:column;gap:24px;display:flex}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;display:grid}.metric-icon-box{width:52px;height:52px;transition:transform var(--transition-fast);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.metric-card:hover .metric-icon-box{transform:scale(1.08)}.icon-box-blue{color:#fff;background:linear-gradient(135deg,#60a5fa 0%,#2563eb 100%);box-shadow:0 8px 16px -2px #2563eb4d}.icon-box-green{color:#fff;background:linear-gradient(135deg,#34d399 0%,#059669 100%);box-shadow:0 8px 16px -2px #0596694d}.icon-box-purple{color:#fff;background:linear-gradient(135deg,#a78bfa 0%,#7c3aed 100%);box-shadow:0 8px 16px -2px #7c3aed4d}.icon-box-orange{color:#fff;background:linear-gradient(135deg,#fbbf24 0%,#d97706 100%);box-shadow:0 8px 16px -2px #d977064d}.metric-label{font-family:var(--font-title);color:var(--text-muted);font-size:.82rem;font-weight:600}.metric-value{font-family:var(--font-title);color:var(--text-dark);letter-spacing:-.03em;margin:2px 0;font-size:1.85rem;font-weight:800;line-height:1.2}.metric-sub{color:var(--text-light);font-size:.75rem;font-weight:500}.charts-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;display:grid}.chart-card{flex-direction:column;padding:20px 20px 16px;display:flex}.chart-body{flex:1;min-height:0;padding-top:8px}.donut-body{flex-direction:column;align-items:center;gap:12px;display:flex}.donut-legend{grid-template-columns:1fr 1fr;gap:6px 16px;width:100%;padding:0 4px;display:grid}.donut-legend-item{align-items:center;gap:7px;min-width:0;display:flex}.donut-legend-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.donut-legend-name{font-family:var(--font-title);color:var(--text-muted);text-transform:capitalize;white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.78rem;font-weight:500;overflow:hidden}.donut-legend-pct{font-family:var(--font-title);color:var(--text-dark);flex-shrink:0;font-size:.78rem;font-weight:700}.chart-tooltip{font-family:var(--font-title);background:#fffffff7;border:1px solid #e5e7ebb3;border-radius:10px;padding:10px 14px;font-size:.85rem;box-shadow:0 8px 24px -4px #0000001f}.chart-tooltip-label{color:var(--text-dark);margin-bottom:4px;font-weight:700}.dashboard-bottom-grid{grid-template-columns:1fr 1fr 1.6fr;gap:24px;display:grid}.dashboard-card{flex-direction:column;padding:24px;display:flex}.dashboard-card-header{border-bottom:1.5px solid var(--border-color);align-items:center;gap:10px;margin-bottom:18px;padding-bottom:12px;display:flex}.dashboard-card-header h2{font-size:1rem;font-family:var(--font-title);color:var(--text-dark);font-weight:700}.header-icon{flex-shrink:0;width:20px;height:20px}.yellow-icon{color:var(--primary-hover)}.info-icon{color:var(--info)}.dashboard-card-body{flex:1}.no-data{color:var(--text-muted);text-align:center;padding:32px 0;font-size:.9rem}.page-loader,.page-error{min-height:300px;font-family:var(--font-title);color:var(--text-muted);justify-content:center;align-items:center;font-size:1.1rem;font-weight:600;display:flex}.page-error{color:var(--danger)}.leaderboard-list{flex-direction:column;gap:10px;display:flex}.leaderboard-item{border:1px solid var(--border-color);transition:all var(--transition-fast);background-color:#fff6;border-radius:12px;align-items:center;padding:10px 12px;display:flex}.leaderboard-item:hover{background-color:#ffffffb3;transform:translate(4px)}.leaderboard-rank-box{flex-shrink:0;justify-content:center;width:30px;margin-right:10px;display:flex}.rank-badge{width:24px;height:24px;font-family:var(--font-title);color:var(--text-muted);background-color:#e2e8f0;border-radius:50%;justify-content:center;align-items:center;font-size:.78rem;font-weight:700;display:flex}.rank-1{background-color:var(--primary-light);color:var(--primary-hover)}.rank-2{color:#475569;background-color:#e2e8f0}.rank-3{color:#ea580c;background-color:#ffedd5}.leaderboard-user-details{flex:1;min-width:0}.leaderboard-name{font-family:var(--font-title);color:var(--text-dark);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:600;overflow:hidden}.leaderboard-sub{color:var(--text-muted);margin-top:2px;font-size:.72rem}.group-lbl{color:var(--primary-hover);font-weight:600}.leaderboard-score-breakdown{flex-direction:column;flex-shrink:0;align-items:flex-end;margin-left:10px;display:flex}.score-detail{color:var(--text-light);font-size:.7rem;font-weight:500}.score-total{font-family:var(--font-title);color:var(--text-dark);font-size:1.05rem;font-weight:800}.group-score-badge{font-family:var(--font-title);color:var(--primary-hover);background-color:var(--primary-bg);border-radius:8px;padding:4px 8px;font-size:.88rem;font-weight:700}.mini-calendar{-webkit-user-select:none;user-select:none;flex-direction:column;gap:0;display:flex}.cal-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.cal-month-label{font-family:var(--font-title);color:var(--text-dark);font-size:.95rem;font-weight:700}.cal-nav-btn{border:1px solid var(--border-color);width:30px;height:30px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:#ffffffb3;border-radius:50%;justify-content:center;align-items:center;display:flex}.cal-nav-btn:hover{background:var(--primary-bg);color:var(--primary-color);border-color:var(--primary-color)}.cal-grid{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.cal-weekday{font-family:var(--font-title);color:var(--text-light);text-align:center;letter-spacing:.04em;padding:4px 0 6px;font-size:.7rem;font-weight:700}.cal-day{aspect-ratio:1;cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #0000;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:2px;display:flex;position:relative}.cal-day:hover{background:var(--primary-bg);border-color:#8b5cf633}.cal-day-num{font-family:var(--font-title);color:var(--text-dark);font-size:.8rem;font-weight:500;line-height:1}.cal-today{background:linear-gradient(135deg, var(--primary-gradient-start), var(--primary-gradient-end));border-color:#0000}.cal-today .cal-day-num{color:#fff;font-weight:800}.cal-selected{background:var(--primary-light);border-color:var(--primary-color)}.cal-selected .cal-day-num{color:var(--primary-hover);font-weight:700}.cal-today.cal-selected{background:linear-gradient(135deg, var(--primary-gradient-start), var(--primary-gradient-end))}.cal-dot-row{justify-content:center;align-items:center;gap:2px;display:flex}.cal-dot{border-radius:50%;width:5px;height:5px;display:inline-block}.cal-selected-info{background:#8b5cf60d;border:1px solid #8b5cf626;border-radius:12px;margin-top:12px;padding:12px 14px;animation:.2s fadeIn}.cal-no-event{color:var(--text-light);text-align:center;padding:4px 0;font-size:.82rem}.cal-event-list{flex-direction:column;gap:8px;list-style:none;display:flex}.cal-event-item{align-items:flex-start;gap:8px;display:flex}.cal-event-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:3px}.cal-event-title{font-family:var(--font-title);color:var(--text-dark);font-size:.83rem;font-weight:600;display:block}.cal-event-time{color:var(--text-muted);margin-top:1px;font-size:.75rem;display:block}@media (width<=1300px){.dashboard-bottom-grid{grid-template-columns:1fr 1fr}.section-groups{grid-column:1/-1}}@media (width<=900px){.dashboard-bottom-grid,.charts-grid{grid-template-columns:1fr}}@media (width<=768px){.donut-legend{grid-template-columns:1fr;gap:8px;padding-left:10px}.section-groups .table-container{overflow-y:visible}.section-groups .custom-table,.section-groups .custom-table thead,.section-groups .custom-table tbody,.section-groups .custom-table tr,.section-groups .custom-table td{width:100%;display:block}.section-groups .custom-table thead{display:none}.section-groups .custom-table tr{border:1px solid var(--border-color);background:#ffffff73;border-radius:12px;margin-bottom:10px;padding:12px 14px;box-shadow:0 4px 10px #8b5cf608}.section-groups .custom-table td{text-align:right;border-bottom:1px dashed #e5e7eb73;justify-content:space-between;align-items:center;min-height:36px;padding:6px 0;display:flex}.section-groups .custom-table td:last-child{border-bottom:none;padding-bottom:0}.section-groups .custom-table td:before{content:attr(data-label);font-weight:700;font-family:var(--font-title);color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em;text-align:left;font-size:.78rem;display:block}}@media (width<=576px){.metrics-grid{grid-template-columns:repeat(2,1fr);gap:10px}.metric-card{flex-direction:column;justify-content:space-between;align-items:flex-start;gap:10px;height:100%;padding:12px 10px}.metric-icon-box{border-radius:10px;width:38px;height:38px}.metric-icon-box svg{width:18px!important;height:18px!important}.metric-value{margin:1px 0;font-size:1.35rem}.metric-label{font-size:.72rem}.metric-sub{font-size:.68rem}}.people-page{box-sizing:border-box;flex-direction:column;gap:20px;height:100%;display:flex;overflow:hidden}.people-filter-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex}.people-filter-bar .search-box{flex:1;align-items:center;min-width:250px;max-width:400px;display:flex;position:relative}.people-filter-bar .search-icon{color:var(--text-light);position:absolute;left:14px}.people-filter-bar .search-input{padding-left:40px}.people-filter-bar .filter-group{align-items:center;gap:12px;display:flex}.filter-select{width:180px}.add-btn{padding:10px 16px}.people-table-container{flex-direction:column;flex:1;min-height:0;padding:12px;display:flex}.people-page .table-container{flex:1;min-height:0;overflow-y:auto}.people-page .custom-table th{z-index:10;background-color:#f1f5f9;position:sticky;top:0}.user-profile-cell{align-items:center;gap:12px;display:flex}.user-profile-cell .avatar{background-color:var(--primary-bg);width:36px;height:36px;color:var(--primary-hover);font-family:var(--font-title);border-radius:50%;justify-content:center;align-items:center;font-size:.95rem;font-weight:700;display:flex}.user-id-sub{color:var(--text-light);font-size:.75rem}.contact-details{flex-direction:column;display:flex}.phone-sub{color:var(--text-muted);margin-top:2px;font-size:.8rem}.notes-cell{white-space:nowrap;text-overflow:ellipsis;max-width:200px;overflow:hidden}.action-buttons{align-items:center;gap:8px;display:flex}.btn-icon{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:6px;display:flex}.btn-icon:hover{color:var(--text-dark);background-color:#f1f5f9}.btn-icon-danger:hover{background-color:var(--danger-bg);color:var(--danger)}.modal-header h2{font-size:1.25rem;font-family:var(--font-title);color:var(--text-dark)}.btn-close{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:6px;display:flex}.btn-close:hover{color:var(--text-dark);background-color:#f1f5f9}.modal-form{flex-direction:column;gap:16px;display:flex}.modal-form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.credentials-box{border:1px solid var(--border-color);background-color:#f8fafc;border-radius:12px;margin-top:8px;padding:16px}.checkbox-group{align-items:center;gap:10px;display:flex}.checkbox-group input{width:16px;height:16px;accent-color:var(--primary-color);cursor:pointer}.checkbox-group label{color:var(--text-dark);cursor:pointer;font-size:.9rem;font-weight:500}.modal-actions{border-top:1px solid var(--border-color);justify-content:flex-end;gap:12px;margin-top:14px;padding-top:18px;display:flex}@media (width<=768px){.people-filter-bar{flex-direction:column;align-items:stretch;gap:12px;padding:12px}.people-filter-bar .search-box{width:100%;min-width:0;max-width:none}.people-filter-bar .filter-group{gap:10px;width:100%;display:flex}.filter-select{flex:1;width:auto}.add-btn{white-space:nowrap;flex:1;justify-content:center}.people-table-container{box-shadow:none;background:0 0;border:none;padding:8px}.people-page .table-container{overflow-y:visible}.custom-table,.custom-table thead,.custom-table tbody,.custom-table tr,.custom-table td{width:100%;display:block}.custom-table thead{display:none}.custom-table tr{background:var(--card-bg);border:1px solid var(--border-color);box-shadow:var(--card-shadow);transition:transform var(--transition-normal);border-radius:16px;margin-bottom:12px;padding:16px}.custom-table tr:hover td{background-color:#0000!important}.custom-table tr:hover{transform:translateY(-2px)}.custom-table td{text-align:right;border-bottom:1px dashed #e5e7eb73;justify-content:space-between;align-items:center;min-height:42px;padding:8px 0;display:flex}.custom-table td:last-child{border-bottom:none;padding-bottom:0}.custom-table td:before{content:attr(data-label);font-weight:700;font-family:var(--font-title);color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;text-align:left;font-size:.82rem;display:block}.user-profile-cell{text-align:right;justify-content:flex-end}.contact-details{align-items:flex-end}.notes-cell{white-space:normal;word-break:break-all;max-width:180px;text-overflow:unset}}.groups-page{flex-direction:column;gap:24px;display:flex}.page-header-icon{background:linear-gradient(135deg, var(--primary-color), var(--primary-hover));width:48px;height:48px;color:var(--primary-contrast,#fff);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.groups-stats-row{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.groups-stat-card{flex-direction:column;gap:4px;padding:20px 24px;display:flex}.groups-stat-label{color:var(--text-muted);font-size:.85rem;font-weight:500}.groups-stat-value{font-size:2rem;font-weight:700;font-family:var(--font-title);color:var(--text-dark)}.groups-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px;display:grid}.no-data-state{text-align:center;color:var(--text-muted);flex-direction:column;grid-column:1/-1;align-items:center;gap:12px;padding:60px 24px;display:flex}.no-data-icon{color:var(--primary-color);opacity:.6}.no-data-state h3{color:var(--text-dark);font-size:1.1rem}.no-data-state p{font-size:.9rem}.group-card{flex-direction:column;gap:14px;padding:22px;display:flex}.group-card-header{align-items:flex-start;gap:12px;display:flex}.group-card-icon{background:var(--primary-bg);width:42px;height:42px;color:var(--primary-hover);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.group-card-meta{flex-direction:column;flex:1;gap:6px;display:flex}.group-name{color:var(--text-dark);font-size:1.05rem;font-weight:600}.group-category-badge{align-self:flex-start}.group-card-actions{gap:6px;display:flex}.group-description{color:var(--text-muted);font-size:.9rem;line-height:1.5}.group-card-footer{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-top:12px;display:flex}.group-members-count{color:var(--text-muted);align-items:center;gap:6px;font-size:.88rem;display:flex}.expand-members-btn{color:var(--primary-hover);cursor:pointer;transition:background var(--transition-fast);font-size:.85rem;font-weight:600;font-family:var(--font-title);background:0 0;border:none;border-radius:8px;align-items:center;gap:5px;padding:6px 10px;display:flex}.expand-members-btn:hover{background:var(--primary-bg)}.group-members-list{border-top:1px dashed var(--border-color);padding-top:14px}.members-list-inner{grid-template-columns:1fr 1fr;gap:8px;max-height:200px;display:grid;overflow-y:auto}.member-chip{background:var(--bg-color);border:1px solid var(--border-color);border-radius:10px;align-items:center;gap:9px;padding:8px 12px;display:flex}.member-chip-avatar{background:linear-gradient(135deg, var(--primary-color), var(--primary-hover));width:30px;height:30px;color:var(--primary-contrast,#fff);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.member-chip-info{flex-direction:column;display:flex;overflow:hidden}.member-chip-name{color:var(--text-dark);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.member-chip-school{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.no-members{color:var(--text-muted);text-align:center;padding:12px;font-size:.88rem}.modal-close-btn{background:var(--bg-color);width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:background var(--transition-fast);border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.delete-modal{text-align:center;max-width:420px}.delete-modal h3{color:var(--danger);margin-bottom:12px}.delete-modal p{color:var(--text-muted);margin-bottom:4px;font-size:.93rem}.page-loader{text-align:center;color:var(--text-muted);padding:60px;font-size:1rem}@media (width<=768px){.page-header-bar{flex-direction:column;align-items:stretch;gap:12px;padding:16px}.page-header-right{flex-direction:column;align-items:stretch;gap:12px;width:100%}.page-header-right .search-box,.page-header-right .btn,.search-input-inline{width:100%}.page-header-right .btn{justify-content:center}.groups-stats-row{grid-template-columns:1fr;gap:12px}.groups-stat-card{padding:14px 18px}.groups-stat-value{font-size:1.6rem}.groups-grid{grid-template-columns:1fr;gap:16px}.group-card{padding:16px}.members-list-inner{grid-template-columns:1fr;gap:6px;max-height:250px}}.activities-page{flex-direction:column;gap:24px;display:flex}.act-icon{color:#fff;background:linear-gradient(135deg,#3b82f6,#6366f1)}.filter-select-wrap{align-items:center;display:flex;position:relative}.filter-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:10px}.filter-select{border:1px solid var(--border-color);font-family:var(--font-body);color:var(--text-dark);cursor:pointer;appearance:none;transition:all var(--transition-fast);background:#fff;border-radius:10px;padding:9px 14px 9px 32px;font-size:.9rem}.filter-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-bg);outline:none}.activities-section{flex-direction:column;gap:14px;display:flex}.activities-section-title{align-items:center;gap:10px;display:flex}.activities-section-title h3{color:var(--text-dark);font-size:1rem}.section-count{color:var(--text-muted);font-weight:500}.section-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.upcoming-dot{background:var(--success)}.past-dot{background:var(--text-muted)}.activities-list{flex-direction:column;gap:12px;display:flex}.no-data-inline{color:var(--text-muted);border:1px dashed var(--border-color);background:#fff;border-radius:12px;padding:20px 24px;font-size:.9rem}.activity-card{transition:transform var(--transition-normal), box-shadow var(--transition-normal);align-items:stretch;gap:0;display:flex;overflow:hidden}.activity-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px -4px #00000014}.upcoming-card{border-left:4px solid var(--primary-color)}.past-card{border-left:4px solid var(--text-muted);opacity:.85}.activity-card-date-col{border-right:1px solid var(--border-color);background:#f8fafccc;flex-shrink:0;align-items:center;padding:20px;display:flex}.activity-date-block{flex-direction:column;align-items:center;min-width:50px;display:flex}.date-day{font-size:1.8rem;font-weight:800;font-family:var(--font-title);color:var(--primary-hover);line-height:1}.date-month{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:700}.date-year{color:var(--text-light);font-size:.7rem}.activity-card-body{flex-direction:column;flex:1;justify-content:center;padding:18px 20px;display:flex}.activity-card-top{flex-direction:column;gap:6px;display:flex}.activity-title-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.activity-title{color:var(--text-dark);font-size:1rem;font-weight:600}.activity-desc{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.88rem;line-height:1.5;display:-webkit-box;overflow:hidden}.activity-meta{flex-wrap:wrap;align-items:center;gap:16px;margin-top:4px;display:flex}.activity-meta-item{color:var(--text-muted);align-items:center;gap:5px;font-size:.82rem;display:flex}.activity-card-actions{border-left:1px solid var(--border-color);flex-direction:column;justify-content:center;gap:8px;padding:16px;display:flex}.act-modal{max-width:600px!important}.form-grid-2{grid-template-columns:1fr 1fr;gap:0 16px;display:grid}.error-banner{background:var(--danger-bg);color:var(--danger);border:1px solid #fecaca;border-radius:10px;justify-content:space-between;align-items:center;padding:12px 16px;font-size:.9rem;display:flex}.error-banner button{cursor:pointer;color:var(--danger);background:0 0;border:none}@media (width<=768px){.page-header-bar{flex-direction:column;align-items:stretch;gap:16px;padding:16px}.page-header-right{flex-direction:column;align-items:stretch;gap:12px;width:100%}.page-header-right .search-box,.page-header-right .filter-select-wrap,.page-header-right .btn,.search-input-inline,.filter-select{width:100%}.page-header-right .btn{justify-content:center}}@media (width<=576px){.activity-card{flex-direction:column;align-items:stretch}.activity-card-date-col{border-right:none;border-bottom:1px solid var(--border-color);background:#f8fafcf2;width:100%;padding:10px 16px}.activity-date-block{flex-direction:row;align-items:center;gap:8px;min-width:auto}.date-day{font-size:1.2rem}.date-month,.date-year{font-size:.78rem}.activity-card-body{padding:14px 16px}.activity-desc{-webkit-line-clamp:4}.activity-card-actions{border-left:none;border-top:1px solid var(--border-color);background:#fff3;flex-direction:row;justify-content:flex-end;gap:12px;padding:10px 16px}}.scores-page{flex-direction:column;gap:20px;display:flex}.scores-icon{background:linear-gradient(135deg, var(--primary-color), var(--primary-hover));color:var(--primary-contrast,#fff)}.scores-tabs{gap:8px;display:flex}.score-tab{border:1px solid var(--border-color);font-family:var(--font-title);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:#fff;border-radius:12px;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:600;display:flex}.score-tab:hover{background:var(--bg-color)}.tab-active{background:var(--primary-color)!important;color:var(--primary-contrast,#fff)!important;border-color:var(--primary-color)!important}.podium-row{grid-template-columns:1fr 1.15fr 1fr;align-items:end;gap:16px;display:grid}.podium-card{text-align:center;flex-direction:column;align-items:center;gap:6px;padding:24px 16px 20px;display:flex}.podium-1{border-top:3px solid var(--primary-color);padding-top:32px}.podium-2{border-top:3px solid #9ca3af}.podium-3{border-top:3px solid #cd7f32}.podium-medal{font-size:1.8rem}.podium-avatar{background:linear-gradient(135deg, var(--primary-color), var(--primary-hover));width:52px;height:52px;color:var(--primary-contrast,#fff);border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;font-weight:800;display:flex}.podium-name{color:var(--text-dark);font-size:.95rem;font-weight:700;font-family:var(--font-title)}.podium-group{color:var(--text-muted);font-size:.78rem}.podium-score{font-size:1.8rem;font-weight:800;font-family:var(--font-title);color:var(--primary-hover);margin-top:4px;line-height:1}.podium-score-lbl{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.rank-badge-pill{width:28px;height:28px;font-size:.8rem;font-weight:800;font-family:var(--font-title);border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.rank-gold{color:#92400e;background:#fef3c7}.rank-silver{color:#6b7280;background:#f3f4f6}.rank-bronze{color:#92400e;background:#fef2f2}.rank-default{background:var(--bg-color);color:var(--text-muted)}.leaderboard-table-wrap{overflow-x:auto}.lb-participant{align-items:center;gap:10px;display:flex}.lb-avatar{background:linear-gradient(135deg, var(--primary-color), var(--primary-hover));width:34px;height:34px;color:var(--primary-contrast,#fff);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.lb-avatar.sm{width:28px;height:28px;font-size:.75rem}.lb-name{color:var(--text-dark);font-size:.93rem;font-weight:600}.lb-school{color:var(--text-muted);font-size:.78rem}.score-pill{background:var(--bg-color);color:var(--text-dark);border-radius:8px;padding:4px 10px;font-size:.85rem;font-weight:600;display:inline-block}.total-score-val{color:var(--primary-hover);font-size:1rem;font-family:var(--font-title)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (width<=768px){.page-header-bar{flex-direction:column;align-items:stretch;gap:12px;padding:16px}.page-header-right{flex-direction:column;align-items:stretch;gap:12px;width:100%}.page-header-right .search-box,.page-header-right .btn,.search-input-inline{width:100%}.page-header-right .btn{justify-content:center}.scores-tabs{width:100%}.score-tab{border-radius:10px;flex:1;justify-content:center;padding:10px 8px;font-size:.85rem}.leaderboard-table-wrap,.records-section .glass-card{box-shadow:none;background:0 0;border:none}.records-section .table-container{overflow-y:visible}.custom-table,.custom-table thead,.custom-table tbody,.custom-table tr,.custom-table td{width:100%;display:block}.custom-table thead{display:none}.custom-table tr{background:var(--card-bg);border:1px solid var(--border-color);box-shadow:var(--card-shadow);border-radius:16px;margin-bottom:12px;padding:14px 16px}.custom-table tr:hover td{background-color:#0000!important}.custom-table td{text-align:right;border-bottom:1px dashed #e5e7eb73;justify-content:space-between;align-items:center;min-height:42px;padding:8px 0;display:flex}.custom-table td:last-child{border-bottom:none;padding-bottom:0}.custom-table td:before{content:attr(data-label);font-weight:700;font-family:var(--font-title);color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;text-align:left;font-size:.8rem;display:block}.lb-participant{text-align:right;justify-content:flex-end}}@media (width<=576px){.podium-row{grid-template-columns:1fr;align-items:stretch;gap:10px}.podium-card{border:1px solid var(--border-color);box-shadow:var(--card-shadow);border-radius:14px;flex-direction:row;justify-content:space-between;align-items:center;padding:12px 16px}.podium-1{border-top:none;border-left:4px solid var(--primary-color);padding-top:12px}.podium-2{border-top:none;border-left:4px solid #9ca3af}.podium-3{border-top:none;border-left:4px solid #cd7f32}.podium-medal{order:1;font-size:1.4rem}.podium-avatar{order:2;width:38px;height:38px;margin:0 10px;font-size:.95rem}.podium-name{text-align:left;white-space:nowrap;text-overflow:ellipsis;flex:1;order:3;font-size:.88rem;overflow:hidden}.podium-group{display:none}.podium-score{order:4;margin-top:0;font-size:1.3rem}.podium-score-lbl{order:5;margin-left:2px;font-size:.72rem}}.attendance-page{flex-direction:column;gap:20px;display:flex}.att-icon{color:#fff;background:linear-gradient(135deg,#10b981,#059669)}.activity-selector{flex-wrap:wrap;align-items:center;gap:16px;padding:20px 24px;display:flex}.selector-label{font-weight:600;font-family:var(--font-title);color:var(--text-dark);white-space:nowrap;align-items:center;gap:8px;display:flex}.activity-select{flex:1;min-width:280px}.att-stats-row{grid-template-columns:repeat(4,auto) 1fr;align-items:center;gap:12px;display:grid}.att-stat{text-align:center;flex-direction:column;gap:2px;padding:16px 20px;display:flex}.att-stat-val{font-size:1.8rem;font-weight:800;font-family:var(--font-title);line-height:1}.att-stat-lbl{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:600}.att-stat-total .att-stat-val{color:var(--text-dark)}.att-stat-present .att-stat-val{color:var(--success)}.att-stat-absent .att-stat-val{color:var(--danger)}.att-stat-rate .att-stat-val{color:var(--primary-hover)}.att-rate-bar-wrap{border:1px solid var(--border-color);background:#fff;border-radius:16px;flex-direction:column;gap:8px;padding:16px 20px;display:flex}.att-rate-bar{background:var(--bg-color);border-radius:99px;width:100%;height:10px;overflow:hidden}.att-rate-fill{background:linear-gradient(90deg, var(--primary-color), var(--success));border-radius:99px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.att-rate-text{color:var(--text-muted);font-size:.85rem;font-weight:600}.att-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.att-mark-btns{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.att-mark-btn{padding:8px 14px!important;font-size:.85rem!important}.attendance-grid{overflow:hidden}.att-grid-header{border-bottom:1px solid var(--border-color);color:var(--text-muted);font-size:.85rem;font-weight:600;font-family:var(--font-title);background:#f3f4f6b3;grid-template-columns:2fr 2fr 1.5fr 1.2fr;padding:12px 20px;display:grid}.att-grid-row{border-bottom:1px solid var(--border-color);transition:background var(--transition-fast);grid-template-columns:2fr 2fr 1.5fr 1.2fr;align-items:center;padding:14px 20px;display:grid}.att-grid-row:last-child{border-bottom:none}.row-present{background:#10b9810a}.row-absent{background:#ef444408}.row-clickable{cursor:pointer}.row-clickable:hover{background:var(--primary-bg)!important}.att-participant-info{align-items:center;gap:10px;display:flex}.att-avatar{background:linear-gradient(135deg, var(--primary-color), var(--primary-hover));width:34px;height:34px;color:var(--primary-contrast,#fff);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.att-name{color:var(--text-dark);font-size:.93rem;font-weight:600}.att-cell{color:var(--text-muted);font-size:.88rem}.att-status-cell{align-items:center;display:flex}.badge{align-items:center;gap:4px;display:inline-flex}.att-empty-state{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:60px 24px;display:flex}.empty-icon{color:var(--primary-color);opacity:.5}.att-empty-state h3{color:var(--text-dark);font-size:1.1rem}.att-empty-state p{font-size:.9rem}.search-input-inline:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #8b5cf61f}@media (width<=768px){.page-header-bar,.activity-selector{flex-direction:column;align-items:stretch;gap:12px;padding:16px}.activity-select{width:100%;min-width:0}.att-stats-row{grid-template-columns:repeat(2,1fr);gap:10px}.att-stat{padding:12px}.att-stat-val{font-size:1.4rem}.att-rate-bar-wrap{grid-column:1/-1;width:100%;padding:12px 16px}.att-controls{flex-direction:column;align-items:stretch;gap:12px;padding:16px}.att-controls .search-box,.att-controls .search-input-inline{width:100%}.att-mark-btns{flex-direction:column;align-items:stretch;gap:8px;width:100%}.att-mark-btn,.att-mark-btns .btn{justify-content:center;width:100%}.att-grid-header{display:none}.attendance-grid{box-shadow:none;-webkit-backdrop-filter:none;background:0 0;border:none;overflow:visible}.att-grid-row{border:1px solid var(--border-color);background:var(--card-bg);width:100%;box-shadow:var(--card-shadow);transition:background var(--transition-fast), border-color var(--transition-fast);border-radius:16px;margin-bottom:12px;padding:14px 16px;display:block}.att-grid-row.row-present{background:var(--success-bg);border-color:#10b98140}.att-grid-row.row-absent{background:var(--danger-bg);border-color:#ef444426}.att-participant-info{border-bottom:1px dashed #e5e7eb73;margin-bottom:4px;padding:6px 0 10px}.att-cell,.att-status-cell{text-align:right;border-bottom:1px dashed #e5e7eb73;justify-content:space-between;align-items:center;min-height:38px;padding:8px 0;display:flex}.att-status-cell{border-bottom:none;padding-bottom:0}.att-cell:before,.att-status-cell:before{content:attr(data-label);font-weight:700;font-family:var(--font-title);color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;text-align:left;font-size:.8rem;display:block}.att-empty-state{padding:40px 16px}}.announcements-page{flex-direction:column;gap:20px;display:flex}.ann-icon{color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706)}.ann-empty{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:60px 24px;display:flex}.ann-empty-icon{color:var(--primary-color);opacity:.5}.ann-empty h3{color:var(--text-dark);font-size:1.1rem}.announcements-list{flex-direction:column;gap:20px;display:flex}.ann-section{flex-direction:column;gap:12px;display:flex}.ann-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;font-weight:700;font-family:var(--font-title);align-items:center;gap:6px;padding:0 4px;display:flex}.ann-card{transition:transform var(--transition-normal), box-shadow var(--transition-normal);flex-direction:column;gap:14px;padding:22px 24px;display:flex}.ann-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px -4px #00000012}.ann-card-pinned{border-left:4px solid var(--primary-color);background:linear-gradient(135deg,#fefce899,#ffffffe6)}.ann-card-header{flex-direction:column;gap:6px;display:flex}.ann-card-title-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.ann-pin-badge{background:var(--primary-bg);color:var(--primary-hover);font-size:.75rem;font-weight:700;font-family:var(--font-title);border:1px solid var(--primary-light);border-radius:99px;align-items:center;gap:4px;padding:3px 10px;display:inline-flex}.ann-card-title{color:var(--text-dark);font-size:1.05rem;font-weight:700}.ann-card-meta{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.ann-date,.ann-expiry{color:var(--text-muted);align-items:center;gap:5px;font-size:.82rem;display:flex}.ann-expiry{color:var(--danger)}.ann-text{color:var(--text-dark);white-space:pre-wrap;font-size:.93rem;line-height:1.7}.ann-text-clamp{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.ann-expand-btn{color:var(--primary-hover);cursor:pointer;font-size:.85rem;font-weight:600;font-family:var(--font-title);background:0 0;border:none;margin-top:8px;padding:0}.ann-expand-btn:hover{text-decoration:underline}.ann-card-actions{border-top:1px solid var(--border-color);align-items:center;gap:8px;padding-top:12px;display:flex}.icon-btn-pin{background:var(--primary-bg);color:var(--primary-hover)}.icon-btn-pin:hover{background:var(--primary-light)}.ann-modal{max-width:580px!important}.form-check{background:var(--bg-color);border:1px solid var(--border-color);border-radius:10px;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;display:flex}.form-checkbox{width:18px;height:18px;accent-color:var(--primary-color);cursor:pointer}.form-check-label{color:var(--text-dark);cursor:pointer;font-size:.9rem;font-weight:600;font-family:var(--font-title)}.search-box{align-items:center;display:flex;position:relative}.search-icon-inner{color:var(--text-muted);pointer-events:none;position:absolute;left:12px}.search-input-inline{border:1px solid var(--border-color);font-family:var(--font-body);color:var(--text-dark);width:220px;transition:all var(--transition-fast);background:#fff;border-radius:10px;padding:9px 14px 9px 36px;font-size:.9rem}.search-input-inline:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-bg);outline:none}.banner-msg{border-radius:10px;justify-content:space-between;align-items:center;padding:12px 16px;font-size:.9rem;display:flex}.banner-success{background:var(--success-bg);color:var(--success);border:1px solid #a7f3d0}.banner-error{background:var(--danger-bg);color:var(--danger);border:1px solid #fecaca}.banner-msg button{cursor:pointer;color:inherit;background:0 0;border:none}.page-loader{text-align:center;color:var(--text-muted);padding:60px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-header h3{color:var(--text-dark);font-size:1.1rem}.modal-close-btn{background:var(--bg-color);width:32px;height:32px;color:var(--text-muted);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.modal-close-btn:hover{background:var(--danger-bg);color:var(--danger)}.modal-actions{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.icon-btn{cursor:pointer;width:32px;height:32px;transition:all var(--transition-fast);border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.icon-btn-edit{background:var(--info-bg);color:var(--info)}.icon-btn-edit:hover{background:#dbeafe}.icon-btn-danger{background:var(--danger-bg);color:var(--danger)}.icon-btn-danger:hover{background:#fee2e2}.ai-page{height:calc(100vh - var(--header-height) - 72px);flex-direction:column;gap:20px;display:flex}.ai-icon{background:linear-gradient(135deg, var(--primary-color), var(--primary-hover));color:#fff}.ai-chat-container{flex-direction:column;flex:1;padding:0;display:flex;overflow:hidden}.ai-messages{flex-direction:column;flex:1;gap:16px;padding:24px;display:flex;overflow-y:auto}.ai-message{align-items:flex-start;gap:12px;display:flex}.msg-user{flex-direction:row-reverse}.msg-avatar{flex-shrink:0}.user-avatar-icon,.bot-avatar-icon{background:linear-gradient(135deg, var(--primary-color), var(--primary-hover));width:34px;height:34px;color:var(--primary-contrast,#fff);border-radius:50%;justify-content:center;align-items:center;display:flex}.msg-bubble{border-radius:16px;max-width:75%;padding:14px 18px;font-size:.93rem;line-height:1.65}.msg-assistant .msg-bubble{border:1px solid var(--border-color);color:var(--text-dark);background:#fff;border-top-left-radius:4px}.msg-user .msg-bubble{background:linear-gradient(135deg, var(--primary-color), var(--primary-hover));color:var(--primary-contrast,#fff);border-top-right-radius:4px}.msg-text{font-family:var(--font-body);white-space:pre-wrap;word-break:break-word;margin:0;font-size:.93rem;line-height:1.65}.typing-indicator{align-items:center;gap:5px;padding:4px 0;display:flex}.typing-indicator span{background:var(--text-muted);border-radius:50%;width:8px;height:8px;animation:1.2s infinite bounce}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{opacity:.5;transform:scale(.7)}40%{opacity:1;transform:scale(1)}}.ai-templates{border-top:1px solid var(--border-color);padding:16px 24px}.templates-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;font-weight:700;font-family:var(--font-title);margin-bottom:10px}.templates-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.template-card{border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast);text-align:center;background:#fff;border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:14px 10px;display:flex}.template-card:hover{border-color:var(--template-color,var(--primary-color));transform:translateY(-2px);box-shadow:0 4px 12px -2px #00000014}.template-icon-wrap{border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.template-label{color:var(--text-dark);font-size:.8rem;font-weight:600;font-family:var(--font-title)}.ai-input-area{border-top:1px solid var(--border-color);flex-direction:column;gap:8px;padding:16px 24px 20px;display:flex}.ai-input-wrap{align-items:flex-end;gap:12px;display:flex}.ai-textarea{border:1px solid var(--border-color);background:var(--bg-color);font-family:var(--font-body);color:var(--text-dark);resize:none;transition:all var(--transition-fast);border-radius:14px;flex:1;padding:12px 16px;font-size:.93rem;line-height:1.5}.ai-textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-bg);background:#fff;outline:none}.ai-send-btn{background:linear-gradient(135deg, var(--primary-color), var(--primary-hover));width:48px;height:48px;color:var(--primary-contrast,#fff);cursor:pointer;transition:all var(--transition-fast);border:none;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.ai-send-btn:hover:not(:disabled){box-shadow:0 4px 12px var(--primary-shadow);transform:scale(1.05)}.ai-send-btn:disabled{opacity:.5;cursor:not-allowed}.ai-disclaimer{color:var(--text-muted);text-align:center;font-size:.75rem}.page-header-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:20px 24px;display:flex}.page-header-left{align-items:center;gap:14px;display:flex}.page-header-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.page-header-title{color:var(--text-dark);margin-bottom:2px;font-size:1.3rem}.page-header-sub{color:var(--text-muted);font-size:.88rem}.page-header-right{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.spin{animation:1s linear infinite spin}.settings-page{flex-direction:column;gap:20px;display:flex}.settings-header-section{margin-bottom:5px}.settings-header-section .subtitle{color:var(--text-muted);font-size:.95rem}.settings-container{grid-template-columns:280px 1fr;align-items:start;gap:24px;display:grid}@media (width<=900px){.settings-container{grid-template-columns:1fr}}.settings-tabs{flex-direction:column;gap:8px;padding:16px;display:flex}.tab-btn{font-family:var(--font-title);color:var(--text-muted);cursor:pointer;text-align:left;transition:all var(--transition-fast);background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;padding:12px 16px;font-size:.95rem;font-weight:600;display:flex}.tab-btn:hover{background-color:var(--bg-color);color:var(--text-dark)}.tab-btn.active{background-color:var(--primary-bg);color:var(--primary-hover)}.settings-content{min-height:480px;padding:28px}.section-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;display:flex}.section-title{color:var(--text-dark);font-size:1.25rem}.settings-form{flex-direction:column;gap:20px;max-width:650px;display:flex}.color-picker-wrapper{align-items:center;gap:12px;display:flex}.color-input{appearance:none;border:1px solid var(--border-color);cursor:pointer;background:0 0;border-radius:10px;width:44px;height:44px;padding:0}.color-input::-webkit-color-swatch-wrapper{padding:0}.color-input::-webkit-color-swatch{border:none;border-radius:9px}.hex-input{max-width:140px;font-family:monospace}.field-hint{color:var(--text-muted);margin-top:2px;font-size:.85rem}.form-section-card{background:var(--bg-color);border:1px solid var(--border-color);border-radius:12px;padding:20px}.form-section-card h4{font-family:var(--font-title);color:var(--text-dark);margin-bottom:8px;font-size:1.05rem}.weights-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}@media (width<=600px){.weights-grid{grid-template-columns:1fr}}.weight-sum-indicator{font-family:var(--font-title);margin-top:16px;font-size:.95rem;font-weight:600}.criteria-input-group{gap:12px;display:flex}.criteria-list{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.criterion-tag{background-color:var(--primary-bg);border:1px solid var(--primary-light);color:var(--primary-hover);border-radius:20px;align-items:center;gap:8px;padding:6px 12px;font-size:.85rem;font-weight:600;display:inline-flex}.remove-tag-btn{color:var(--primary-hover);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:1.1rem;line-height:1;display:flex}.remove-tag-btn:hover{color:var(--danger)}.max-h-500{border:1px solid var(--border-color);border-radius:12px;max-height:520px;overflow-y:auto}.text-nowrap{white-space:nowrap}.text-center{text-align:center}.animate-spin{animation:1s linear infinite spin}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;display:flex}.close-btn{color:var(--text-light);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;font-size:1.5rem}.close-btn:hover{color:var(--text-dark)}.modal-actions{justify-content:flex-end;gap:12px;display:flex}.alert{border-radius:10px;margin-bottom:20px;padding:12px 16px;font-size:.95rem;font-weight:500}.alert-success{background-color:var(--success-bg);color:var(--success);border:1px solid #10b98133}.alert-danger{background-color:var(--danger-bg);color:var(--danger);border:1px solid #ef444433}.error-container{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;max-width:500px;margin:40px auto;padding:60px 24px;display:flex}.error-container h2{color:var(--text-dark);font-size:1.5rem}.error-container p{color:var(--text-muted)}.theme-presets-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:8px;margin-bottom:8px;display:grid}.theme-preset-card{border:2px solid var(--border-color);cursor:pointer;transition:all var(--transition-normal);background-color:#fff6;border-radius:12px;flex-direction:column;gap:12px;padding:16px;display:flex;position:relative;overflow:hidden}.theme-preset-card:hover{border-color:var(--primary-light);box-shadow:var(--card-shadow-hover);background-color:#fffc;transform:translateY(-2px)}.theme-preset-card.active{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-bg);background-color:#ffffffe6}.theme-preset-preview{border:1px solid var(--border-color);border-radius:8px;height:90px;display:flex;position:relative;overflow:hidden}.vibrant-preview{background:linear-gradient(135deg,#f6f1f4 0%,#edf4f8 100%)}.vibrant-preview .preview-sidebar{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#fff9;border-right:1px solid #e5e7eb80;width:25%}.vibrant-preview .preview-content{flex-direction:column;flex:1;gap:6px;padding:8px;display:flex}.vibrant-preview .preview-card{background:#fffc;border:1px solid #e5e7eb4d;border-radius:4px;height:100%;box-shadow:0 4px 10px #8b5cf60d}.classic-preview{background:#f8fafc}.classic-preview .preview-sidebar{background:#fff;border-right:1px solid #e5e7ebe6;width:25%}.classic-preview .preview-content{flex-direction:column;flex:1;gap:6px;padding:8px;display:flex}.classic-preview .preview-card{background:#fff;border:1px solid #e5e7ebcc;border-radius:4px;height:100%}.theme-preset-info{flex-direction:column;gap:4px;display:flex}.preset-name{font-family:var(--font-title);color:var(--text-dark);font-size:.95rem;font-weight:700}.preset-desc{color:var(--text-muted);font-size:.78rem;line-height:1.3}.switch-container{flex-shrink:0;width:50px;height:26px;display:inline-block;position:relative}.switch-container input{opacity:0;width:0;height:0}.switch-slider{cursor:pointer;background-color:var(--border-color);border-radius:34px;transition:all .4s;position:absolute;inset:0}.switch-slider:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:all .4s;position:absolute;bottom:4px;left:4px;box-shadow:0 2px 4px #0000001a}.switch-container input:checked+.switch-slider{background-color:var(--primary-color)}.switch-container input:checked+.switch-slider:before{transform:translate(24px)}.participant-view-page{flex-direction:column;gap:20px;display:flex}.welcome-banner-card{border-left:5px solid var(--primary-color);background:linear-gradient(135deg,#ffffffe6 0%,#fefce899 100%);justify-content:space-between;align-items:center;gap:20px;padding:24px;display:flex}.welcome-banner-left{align-items:center;gap:20px;display:flex}@media (width<=768px){.welcome-banner-card{flex-direction:column;align-items:stretch;gap:16px;padding:20px}.welcome-banner-left{flex-direction:row;align-items:center;gap:16px}.rank-badge-box{flex-direction:row;justify-content:space-between;align-items:center;width:100%;min-width:0;padding:12px 20px}.rank-badge-lbl{font-size:.8rem}.rank-badge-val{font-size:1.4rem}}.participant-large-avatar{background:linear-gradient(135deg, var(--primary-color), var(--primary-hover));width:60px;height:60px;color:var(--primary-contrast,#fff);font-family:var(--font-title);box-shadow:0 4px 10px var(--primary-shadow);border-radius:50%;justify-content:center;align-items:center;font-size:1.6rem;font-weight:700;display:flex}.welcome-title{color:var(--text-dark);font-size:1.4rem}.welcome-sub{color:var(--text-muted);margin-top:2px;font-size:.95rem}.rank-badge-box{background-color:var(--text-dark);color:#fff;border-radius:12px;flex-direction:column;align-items:center;min-width:110px;padding:10px 18px;display:flex}.rank-badge-lbl{font-size:.7rem;font-family:var(--font-title);letter-spacing:.05em;color:var(--text-light);font-weight:600}.rank-badge-val{font-size:1.5rem;font-family:var(--font-title);color:var(--primary-color);font-weight:700}.metrics-row{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}@media (width<=1024px){.metrics-row{grid-template-columns:repeat(2,1fr)}}@media (width<=550px){.metrics-row{grid-template-columns:repeat(2,1fr);gap:12px}.metric-card{border-radius:16px;gap:10px;padding:14px 12px}.metric-icon{border-radius:8px;width:38px;height:38px}.metric-icon svg{width:18px;height:18px}.metric-value{font-size:1.15rem}.metric-label{font-size:.78rem}}.metric-card{align-items:center;gap:16px;padding:18px;display:flex}.metric-icon{border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.metric-yellow{background-color:var(--accent-gold-bg,#e8c96b26);color:var(--accent-gold-dark,#c9a84c)}.metric-green{background-color:var(--success-bg);color:var(--success)}.metric-purple{background-color:var(--primary-bg);color:var(--primary-color)}.metric-blue{background-color:var(--info-bg);color:var(--info)}.metric-info{flex-direction:column;display:flex}.metric-label{color:var(--text-muted);font-size:.85rem}.metric-value{font-family:var(--font-title);color:var(--text-dark);margin-top:2px;font-size:1.3rem;font-weight:700}.portal-container{grid-template-columns:240px 1fr;align-items:start;gap:24px;display:grid}@media (width<=900px){.portal-container{grid-template-columns:1fr;gap:16px}.portal-tabs{white-space:nowrap;scrollbar-width:none;-webkit-overflow-scrolling:touch;flex-direction:row;gap:8px;margin-bottom:4px;padding:8px;overflow-x:auto}.portal-tabs::-webkit-scrollbar{display:none}.portal-tab-btn{flex:none;justify-content:center;gap:8px;padding:10px 16px;font-size:.9rem}.portal-content{padding:16px}}.portal-tabs{flex-direction:column;gap:6px;padding:12px;display:flex}.portal-tab-btn{font-family:var(--font-title);color:var(--text-muted);cursor:pointer;text-align:left;transition:all var(--transition-fast);background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;padding:12px 14px;font-size:.95rem;font-weight:600;display:flex}.portal-tab-btn:hover{background-color:var(--bg-color);color:var(--text-dark)}.portal-tab-btn.active{background-color:var(--primary-bg);color:var(--primary-hover)}.portal-content{min-height:400px;padding:24px}.tab-overview-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}@media (width<=768px){.tab-overview-grid{grid-template-columns:1fr}}.info-block{flex-direction:column;gap:16px;display:flex}.info-block-title{color:var(--text-dark);border-bottom:1px solid var(--border-color);padding-bottom:8px;font-size:1.1rem}.profile-details-list{flex-direction:column;gap:12px;display:flex}.detail-item{flex-direction:column;gap:4px;display:flex}.detail-lbl{text-transform:uppercase;letter-spacing:.02em;color:var(--text-muted);font-size:.8rem;font-weight:600}.detail-val{color:var(--text-dark);font-size:.95rem}.notes-val{background-color:var(--bg-color);border:1px solid var(--border-color);color:var(--text-muted);border-radius:10px;padding:10px 14px;font-size:.9rem;line-height:1.4}.group-info-card{background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:12px;padding:20px}.group-info-header{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.group-category-badge{font-size:.75rem;font-family:var(--font-title);color:var(--primary-hover);background-color:var(--primary-bg);border-radius:4px;align-self:flex-start;padding:2px 8px;font-weight:700;display:inline-block}.group-info-header h5{color:var(--text-dark);font-size:1.15rem}.teammates-section h6{font-family:var(--font-title);color:var(--text-muted);margin-bottom:10px;font-size:.9rem}.teammates-list{flex-direction:column;gap:8px;display:flex}.teammate-row{border:1px solid var(--border-color);background-color:#fff;border-radius:8px;align-items:center;gap:12px;padding:8px 12px;display:flex}.teammate-self{border-color:var(--primary-light);background-color:var(--primary-bg)}.teammate-avatar{width:28px;height:28px;color:var(--text-dark);background-color:#cbd5e1;border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;font-weight:600;display:flex}.teammate-self .teammate-avatar{background-color:var(--primary-color)}.teammate-name{color:var(--text-dark);font-size:.9rem}.scoring-formula-box{background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:12px;padding:16px 20px}.scoring-formula-box h5{color:var(--text-dark);font-size:1rem}.scoring-formula-box p{color:var(--text-muted);margin-top:4px;font-size:.85rem}.weights-pills{flex-wrap:wrap;gap:8px;display:flex}.weight-pill{font-size:.8rem;font-family:var(--font-title);border:1px solid var(--border-color);color:var(--text-dark);background-color:#fff;border-radius:6px;padding:4px 10px;font-weight:600}.feedback-cell{color:var(--text-muted);max-width:280px;font-size:.87rem}.attendance-summary-header{background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:12px;padding:16px 20px;display:flex}.att-stats{gap:32px;display:flex}.att-stat-box{flex-direction:column;display:flex}.att-val{font-size:1.6rem;font-family:var(--font-title);font-weight:700}.att-lbl{color:var(--text-muted);font-size:.8rem;font-weight:500}.status-badge{align-items:center;gap:6px;font-size:.85rem;font-weight:600;display:inline-flex}.status-present{color:var(--success)}.status-absent{color:var(--danger)}.status-unmarked{color:var(--text-light)}.leaderboard-split-row{grid-template-columns:1fr 1fr;gap:24px;display:grid}@media (width<=768px){.leaderboard-split-row{grid-template-columns:1fr}}.leaderboard-col h6{color:var(--text-dark);margin-bottom:12px;font-size:1rem}.leaderboard-list-simple{border:1px solid var(--border-color);background-color:var(--bg-color);border-radius:12px;flex-direction:column;gap:8px;max-height:480px;padding:8px;display:flex;overflow-y:auto}.leaderboard-item-row{border:1px solid var(--border-color);background-color:#fff;border-radius:8px;align-items:center;gap:12px;padding:10px 12px;display:flex}.leaderboard-item-highlight{background-color:var(--primary-bg);border-color:var(--primary-light)}.lb-rank-num{font-family:var(--font-title);color:var(--text-muted);width:24px;font-size:.95rem;font-weight:700}.leaderboard-item-highlight .lb-rank-num{color:var(--primary-hover)}.lb-p-avatar{width:32px;height:32px;color:var(--text-dark);background-color:#f1f5f9;border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;font-weight:600;display:flex}.leaderboard-item-highlight .lb-p-avatar{background-color:var(--primary-color)}.lb-p-info{flex-direction:column;flex:1;display:flex}.lb-p-name{color:var(--text-dark);font-size:.9rem;font-weight:600}.lb-p-group{color:var(--text-muted);font-size:.75rem}.lb-p-score{font-family:var(--font-title);color:var(--text-dark);font-size:1.05rem;font-weight:700}.leaderboard-item-highlight .lb-p-score{color:var(--primary-hover)}.participant-error{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;max-width:400px;margin:80px auto;padding:60px;display:flex}.participant-error h3{color:var(--text-dark);font-size:1.3rem}.participant-error p{color:var(--text-muted)}@media (width<=768px){.participant-view-page .table-container{overflow-y:visible}.participant-view-page .custom-table,.participant-view-page .custom-table thead,.participant-view-page .custom-table tbody,.participant-view-page .custom-table tr,.participant-view-page .custom-table td{width:100%;display:block}.participant-view-page .custom-table thead{display:none}.participant-view-page .custom-table tr{background:var(--card-bg);border:1px solid var(--border-color);box-shadow:var(--card-shadow);transition:transform var(--transition-normal);border-radius:16px;margin-bottom:12px;padding:16px}.participant-view-page .custom-table tr:hover td{background-color:#0000!important}.participant-view-page .custom-table tr:hover{transform:translateY(-2px)}.participant-view-page .custom-table td{text-align:right;box-sizing:border-box;border-bottom:1px dashed #e5e7eb73;justify-content:space-between;align-items:center;min-height:44px;padding:10px 0;display:flex}.participant-view-page .custom-table td:last-child{border-bottom:none;padding-bottom:0}.participant-view-page .custom-table td:before{content:attr(data-label);font-weight:700;font-family:var(--font-title);color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;text-align:left;padding-right:12px;font-size:.82rem;display:block}.participant-view-page .feedback-cell{text-align:right;justify-content:flex-end;max-width:none}.participant-view-page .status-badge{justify-content:flex-end}}@media (width<=550px){.attendance-summary-header{padding:12px}.att-stats{grid-template-columns:1fr 1fr;justify-content:space-between;gap:16px;width:100%;display:grid}.att-stat-box{align-items:center}.scoring-formula-box{padding:12px 16px}.weights-pills{gap:6px}.weight-pill{padding:3px 8px;font-size:.75rem}}.auth-layout{background-color:var(--bg-color);width:100vw;min-height:100vh;display:block}.auth-main{width:100%;min-height:100vh}
