@import"https://fonts.googleapis.com/css2?family=Work+Sans:ital,wght@0,100..900;1,100..900&display=swap";:root{--color-primary: #047857;--color-primary-dark: #123524;--color-font-primary: ;--color-white: rgba(255, 255, 255, .9);--color-primary-dark-transparent: rgba(2, 61, 45, .95);--color-primary-light: rgba(4, 120, 87, .2);--color-accent: #facc15;--color-coin: #FFD700;--font-color-accent: #1f2937;--color-orange: #fbbf24;--color-accent-dark: #b45309;--destructive: #a41d1d;--color-green-soft: #d1fae5;--color-yellow-soft: #fef3c7;--color-blue-soft: #e0f2fe;--color-purple-soft: #ede9fe;--color-red-soft: #fce7f3;--color-gray: #6b7280;--color-gray-light: #f3f4f6;--color-gray-dark: #374151;--font-base: "Work Sans", sans-serif;--font-desc: .75rem;--font-md: 1.125rem;--font-title: 1.75rem;--font-sm: .875rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 4px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .05);--border-gray-light: #e3e5e7;--border-gray-dark: #a7a7a7;--card: #ffffff;--muted: var(--color-gray-light);--chart-1: var(--color-accent-dark);--chart-2: #92400e;--chart-3: #78350f}.container{max-width:960px;margin:0 auto;padding:0 1rem;box-sizing:border-box}.flex-center{display:flex;justify-content:center;align-items:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.text-primary{color:var(--color-primary)}.text-gray{color:var(--color-gray)}.bg-primary{background-color:var(--color-primary);color:#fff}.rounded-md{border-radius:var(--radius-md)}.shadow-sm{box-shadow:var(--shadow-sm)}.profilHeader{margin-bottom:1.5rem}.profilCard{display:flex;justify-content:space-between;align-items:center;background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #00000014;border:1px solid #e5e7eb;gap:1.5rem}.profilLeftSection{display:flex;align-items:center;gap:1.25rem;flex:1}.avatarWrapper{position:relative;flex-shrink:0}.profilAvatar{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid var(--color-primary-dark, #023d2d)}.uploadAvatarBtn{position:absolute;bottom:0;right:0;width:32px;height:32px;background-color:var(--color-primary, #4CAF50);color:#fff;border-radius:50%;border:2px solid white;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0003}.uploadAvatarBtn:hover{background-color:var(--color-primary-dark, #023d2d);transform:scale(1.1)}.profilDetails{display:flex;flex-direction:column;gap:.375rem;min-height:70px}.profilName{font-size:1.25rem;font-weight:700;color:var(--color-primary-dark, #111827);margin:0;line-height:1.3}.profilEmail{font-size:.85rem;color:#6b7280;margin:0}.levelBadge{display:inline-flex;align-items:center;gap:.35rem;background:#4caf501a;color:var(--color-primary-dark, #2E7D32);padding:.35rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;width:fit-content;margin-top:.25rem}.levelBadge svg{color:#ffc107}.badgeTitleSelector{position:relative;margin-top:.5rem}.badgeTitleBtn{display:inline-flex;align-items:center;gap:.4rem;background:linear-gradient(135deg,#fff8e1,#ffecb3);border:1px solid #FFD54F;border-radius:20px;padding:.4rem .875rem;cursor:pointer;transition:all .2s ease;font-size:.8rem;font-weight:600;color:#795548}.badgeTitleBtn:hover{background:linear-gradient(135deg,#ffecb3,#ffe082);transform:translateY(-1px);box-shadow:0 4px 12px #ffc10740}.badgeTitleBtn:disabled{opacity:.7;cursor:not-allowed}.badgeTitleIcon{font-size:.9rem}.badgeTitleText{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badgeTitleBtn svg{transition:transform .2s ease;color:#795548}.badgeTitleBtn svg.rotated{transform:rotate(180deg)}.badgeDropdown{position:absolute;top:calc(100% + 8px);left:0;background:#fff;border-radius:12px;box-shadow:0 8px 30px #00000026;padding:.5rem;z-index:100;min-width:220px;max-width:280px;animation:dropdownFade .2s ease}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.badgeDropdownHeader{font-size:.7rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;padding:.5rem .75rem;border-bottom:1px solid #f3f4f6;margin-bottom:.25rem}.badgeDropdownItem{display:flex;align-items:center;gap:.5rem;width:100%;padding:.6rem .75rem;border:none;background:none;cursor:pointer;border-radius:8px;transition:all .15s ease;text-align:left}.badgeDropdownItem:hover{background-color:#f3f4f6}.badgeDropdownItem.selected{background-color:#4caf501a}.badgeItemIcon{font-size:1rem;flex-shrink:0}.badgeItemInfo{display:flex;flex-direction:column;gap:.1rem;flex:1;min-width:0}.badgeItemName{font-size:.85rem;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.badgeItemReward{font-size:.7rem;color:#ffb800;font-weight:600}.checkMark{color:#4caf50;font-weight:700;font-size:1rem;flex-shrink:0}.profilRightSection{flex-shrink:0}.pointsCard{display:flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,#4caf50,#2e7d32);border-radius:12px;padding:1rem 1.25rem;color:#fff}.pointsIcon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:#fff3;border-radius:50%}.pointsIcon svg{color:gold}.pointsInfo{display:flex;flex-direction:column;gap:.1rem}.pointsLabel{font-size:.7rem;font-weight:500;color:#ffffffd9;text-transform:uppercase;letter-spacing:.5px}.pointsValue{font-size:1.25rem;font-weight:700;color:#fff;line-height:1.2}.uploadSuccessMessage{background-color:#4caf50;color:#fff;padding:12px 16px;border-radius:8px;margin-bottom:12px;text-align:center;font-weight:500;animation:slideDown .3s ease}.profilInfo{display:flex;justify-content:center;align-items:center;flex-direction:column;gap:24px}.profilBadge{background-color:var(--color-gray-light);color:var(--color-primary-dark);border:2px solid var(--color-primary-dark);font-size:1rem;padding:8px 16px;border-radius:6px;font-weight:600;display:flex;margin-top:20px}.badgeSelector{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:24px}.badgeSelector h4{font-size:var(--font-md);font-weight:600;color:var(--color-primary-dark);margin-bottom:8px}.badgeList{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.badgeOption{display:flex;align-items:center;gap:8px;padding:8px 16px;border:2px solid var(--border-gray-light);border-radius:8px;background-color:#f9f9f9;cursor:pointer;transition:all .2s ease;font-size:var(--font-sm);font-weight:500;color:var(--color-primary-dark)}.badgeOption:hover{background-color:var(--color-primary-light);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.badgeOption.selected{border-color:var(--color-primary-dark);background-color:var(--color-primary-light);box-shadow:0 4px 12px #4caf504d}.badgeIconMini{width:24px;height:24px;object-fit:contain;flex-shrink:0}.badgeOptionInfo{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.badgeOptionName{font-weight:600;font-size:.9rem;color:var(--color-primary-dark)}.badgeOptionReward{font-size:.75rem;color:#ffb800;font-weight:700}.avatarWrapper{position:relative;width:fit-content}.uploadAvatarBtn{position:absolute;bottom:0;right:0;background-color:var(--color-primary);color:#fff;border:3px solid white;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0003}.uploadAvatarBtn:hover{background-color:var(--color-primary-dark);transform:scale(1.1);box-shadow:0 4px 12px #0000004d}.uploadAvatarBtn:active{transform:scale(.95)}.uploadSuccessMessage{background-color:#4caf50;color:#fff;padding:12px 16px;border-radius:6px;margin-bottom:12px;text-align:center;font-weight:500;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.uploadModalOverlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.uploadModal{background-color:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:400px;width:100%;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.uploadModalHeader{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-gray-light)}.uploadModalHeader h3{margin:0;font-size:1.2rem;font-weight:600;color:var(--color-primary-dark)}.closeBtn{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:#666;transition:color .2s ease}.closeBtn:hover:not(:disabled){color:var(--color-primary-dark)}.closeBtn:disabled{opacity:.5;cursor:not-allowed}.uploadModalContent{padding:20px;display:flex;flex-direction:column;gap:16px}.previewContainer{display:flex;justify-content:center;align-items:center;background-color:#f5f5f5;border-radius:8px;padding:16px;min-height:150px}.previewImage{max-width:100%;max-height:200px;border-radius:6px;object-fit:contain}.fileInputWrapper{display:flex;justify-content:center}.fileInputLabel{display:flex;align-items:center;justify-content:center;padding:16px 20px;border:2px dashed var(--color-primary);border-radius:8px;background-color:#4caf500d;cursor:pointer;transition:all .2s ease;font-weight:500;color:var(--color-primary)}.fileInputLabel:hover{background-color:#4caf501a;border-color:var(--color-primary-dark)}.errorMessage{background-color:#ffebee;color:#c62828;padding:12px 16px;border-radius:6px;border-left:4px solid #c62828;font-size:.9rem}.uploadInfo{font-size:.85rem;color:#666;text-align:center;margin:0;line-height:1.5}.uploadModalFooter{display:flex;gap:12px;padding:16px 20px;border-top:1px solid var(--border-gray-light);justify-content:flex-end}.cancelBtn,.uploadBtn{padding:10px 20px;border-radius:6px;border:none;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.95rem}.cancelBtn{background-color:var(--color-gray-light);color:var(--color-primary-dark);border:2px solid var(--color-gray-light)}.cancelBtn:hover:not(:disabled){background-color:#e0e0e0;border-color:#d0d0d0}.uploadBtn{background-color:var(--color-primary);color:#fff;border:2px solid var(--color-primary)}.uploadBtn:hover:not(:disabled){background-color:var(--color-primary-dark);border-color:var(--color-primary-dark);box-shadow:0 4px 8px #4caf504d}.uploadBtn:disabled,.cancelBtn:disabled{opacity:.6;cursor:not-allowed}.uploadBtn:active:not(:disabled){transform:scale(.98)}@media(max-width:768px){.profilCard{flex-direction:column;align-items:stretch;padding:1.25rem;gap:1.25rem}.profilLeftSection{flex-direction:column;align-items:center;text-align:center}.profilDetails{align-items:center}.profilRightSection{width:100%}.pointsCard{justify-content:center;padding:.875rem 1rem}.badgeDropdown{left:50%;transform:translate(-50%)}@keyframes dropdownFade{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}}@media(max-width:480px){.profilCard{padding:1rem}.profilAvatar{width:80px;height:80px}.uploadAvatarBtn{width:28px;height:28px}.profilName{font-size:1.1rem}.pointsCard{padding:.75rem;gap:.5rem}.pointsIcon{width:36px;height:36px}.pointsValue{font-size:1.1rem}.badgeTitleBtn{font-size:.75rem;padding:.35rem .65rem}}.badgeRewardsSummary{margin-bottom:24px}.rewardsSummaryCard{background:linear-gradient(135deg,#4caf50,#45a049);border-radius:12px;padding:24px;display:flex;gap:20px;align-items:center;box-shadow:0 4px 12px #4caf504d}.summaryIcon{font-size:3rem;flex-shrink:0}.summaryContent{flex:1;color:#fff}.summaryTitle{margin:0 0 8px;font-size:1.25rem;font-weight:700;color:#fff}.summaryValue{font-size:2rem;font-weight:700;margin:8px 0}.earnedPoints{color:gold}.totalPoints{font-size:1.5rem;opacity:.9}.summaryProgressBar{height:8px;background-color:#ffffff4d;border-radius:4px;overflow:hidden;margin:12px 0}.summaryProgressFill{height:100%;background-color:gold;transition:width .3s ease}.summarySubtext{margin:8px 0 0;font-size:.95rem;opacity:.95}.badgeFilter{display:flex;gap:12px;margin-bottom:24px;padding:0 4px;flex-wrap:wrap}.filterButton{flex:1;min-width:140px;display:flex;align-items:center;gap:12px;padding:16px 20px;background:#1e293b;border:2px solid #334155;border-radius:12px;cursor:pointer;transition:all .3s ease;font-family:inherit}.filterButton:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003;border-color:#4ade80}.filterButton.active{background:linear-gradient(135deg,#4ade80,#22c55e);border-color:#4ade80;box-shadow:0 4px 16px #4ade8066}.filterButton.active .filterLabel,.filterButton.active .filterCount{color:#fff}.filterIcon{font-size:24px;line-height:1;flex-shrink:0}.filterText{display:flex;flex-direction:column;align-items:flex-start;gap:4px;flex:1}.filterLabel{font-size:14px;font-weight:600;color:#cbd5e1;transition:color .3s ease}.filterCount{font-size:20px;font-weight:700;color:#4ade80;transition:color .3s ease}.filterResults{margin-bottom:20px;padding:12px 20px;background:#1e293b;border-left:4px solid #4ade80;border-radius:8px}.resultsText{margin:0;color:#cbd5e1;font-size:14px}.resultsText strong{color:#4ade80;font-weight:700}.emptyState{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.badgeCardsLoading{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#94a3b8}.badgeCardsLoading .loadingSpinner{width:40px;height:40px;border:3px solid #334155;border-top-color:#4ade80;border-radius:50%;animation:badgeSpinner .8s linear infinite;margin-bottom:16px}@keyframes badgeSpinner{to{transform:rotate(360deg)}}.badgeCardsLoading p{margin:0;font-size:14px}.emptyIcon{font-size:64px;margin-bottom:16px;opacity:.8}.emptyTitle{font-size:20px;font-weight:600;color:#cbd5e1;margin:0 0 8px}.emptySubtext{font-size:14px;color:#94a3b8;margin:0;max-width:400px}.achievementList{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;width:100%}.achievementCard{background-color:#1e293b;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;min-height:400px;transition:transform .2s ease,box-shadow .2s ease}.achievementCard:hover{transform:translateY(-4px);box-shadow:0 6px 16px #0003}.achievementThumbnail{background-color:#0f172a;min-height:180px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.thumbnailIcon{font-size:3rem;color:var(--color-primary)}.badgeEmojiIcon{font-size:4rem;line-height:1;text-shadow:0 4px 12px rgba(0,0,0,.3);filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.achievementCard.unlocked .badgeEmojiIcon{animation:badgeGlow 2s ease-in-out infinite alternate}@keyframes badgeGlow{0%{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));transform:scale(1)}to{filter:drop-shadow(0 4px 16px rgba(255,215,0,.4));transform:scale(1.05)}}.achievementContent{padding:1rem;display:flex;flex-direction:column;gap:.5rem;flex:1;overflow-y:auto}.achievementTitle{font-size:1rem;font-weight:600;color:#fff;margin-bottom:.5rem}.achievementDesc{font-size:.85rem;color:#cbd5e1;margin-bottom:.75rem;line-height:1.4}.badgeRewardSection{display:flex;align-items:center;gap:8px;margin:8px 0;padding:8px 12px;background-color:#ffd70026;border-radius:6px;border:1px solid rgba(255,215,0,.3)}.rewardLabel{display:flex;align-items:center;font-size:.85rem;color:#fbbf24;font-weight:500}.rewardPoints{font-size:.95rem;font-weight:700;color:gold;margin-left:auto}.achievementTags{display:flex;gap:.5rem;font-size:.75rem;color:#94a3b8;text-transform:uppercase;margin-top:8px}.badgeTag{background-color:#334155;padding:2px 6px;border-radius:4px}.unlockedDate{font-size:.75rem;color:#94a3b8;margin-top:8px;font-style:italic}.progressBar{height:6px;background-color:#475569;border-radius:4px;overflow:hidden;margin-top:.5rem}.progressFill{height:100%;background-color:var(--color-primary);transition:width .3s ease}.progressText{font-size:.75rem;color:#cbd5e1;margin-top:.25rem}.achievementCard.unlocked{border:2px solid #FFD700;box-shadow:0 4px 12px #ffd7004d}.achievementCard.unlocked .achievementThumbnail{background:linear-gradient(135deg,#0f172a,#1e3a1e)}.achievementCard.locked{border:2px solid #475569;opacity:.85}.achievementCard.locked .thumbnailIcon{color:#64748b}.achievementTop{display:flex;align-items:center;justify-content:space-between;gap:12px}.badgeIconWrapper{background-color:var(--color-primary-light);border-radius:var(--radius-sm);padding:8px;display:flex;align-items:center;justify-content:center}.badgeIcon{color:var(--color-primary-dark)}.badgeIcon.complete{color:var(--color-primary)}.badgeInfo{flex:1}.achievementSyarat{font-size:var(--font-sm);color:var(--color-gray)}.badgePoin{font-size:var(--font-sm);font-weight:600;color:var(--color-primary);white-space:nowrap}@media(max-width:768px){.badgeRewardsSummary{margin-bottom:16px}.rewardsSummaryCard{flex-direction:column;text-align:center;padding:20px}.summaryIcon{font-size:2.5rem}.summaryValue{font-size:1.5rem}.badgeFilter{gap:8px}.filterButton{min-width:auto;flex:1 1 calc(50% - 4px);padding:12px 14px}.filterIcon{font-size:18px}.filterLabel{font-size:.75rem}.filterCount{font-size:1rem}.filterResults{padding:10px 16px}.resultsText{font-size:13px}.achievementList{grid-template-columns:repeat(2,1fr);gap:12px}.achievementCard{min-height:320px}.achievementThumbnail{min-height:120px}.thumbnailIcon{font-size:2rem}.achievementContent{padding:.75rem}.achievementTitle{font-size:.85rem}.achievementDesc{font-size:.75rem;line-height:1.4}.badgeRewardSection{padding:5px 8px;font-size:.7rem}.rewardLabel{font-size:.65rem}.rewardPoints{font-size:.75rem}.badgeTag{font-size:.65rem;padding:3px 6px}.progressText,.unlockedDate{font-size:.7rem}.emptyIcon{font-size:48px}.emptyTitle{font-size:18px}.emptySubtext{font-size:13px}}@media(max-width:480px){.achievementList{grid-template-columns:repeat(2,1fr);gap:10px}.achievementCard{min-height:300px}.achievementThumbnail{min-height:100px}.thumbnailIcon{font-size:1.75rem}.achievementContent{padding:.625rem}.achievementTitle{font-size:.8rem}.achievementDesc{font-size:.7rem}.badgeRewardSection{padding:4px 6px}.badgeTag{font-size:.6rem;padding:2px 5px}}@media(max-width:360px){.achievementList{grid-template-columns:repeat(2,1fr);gap:8px}.achievementCard{min-height:280px}.achievementThumbnail{min-height:90px}.thumbnailIcon{font-size:1.5rem}.achievementContent{padding:.5rem}.achievementTitle{font-size:.75rem}.achievementDesc{font-size:.65rem}.badgeRewardSection{padding:3px 5px;gap:4px}.rewardLabel{font-size:.6rem}.rewardPoints{font-size:.7rem}.badgeTag{font-size:.55rem;padding:2px 4px}.progressText,.unlockedDate{font-size:.65rem}}.userDataContainer{width:100%;display:flex;flex-direction:column;gap:1.5rem;font-family:var(--font-base);padding:1.5rem;max-width:1200px;margin:0 auto}.userStatsSection{display:flex;flex-direction:column;gap:1.5rem}.userStatsSection:before{content:"Statistik Profil Anda";font-size:1.1rem;font-weight:600;color:var(--color-gray-dark);text-transform:capitalize;letter-spacing:.3px}.statsContainer{display:flex;flex-direction:column;gap:1.5rem}.statsGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;animation:fadeInUp .5s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.statsGrid>:nth-child(1){animation-delay:.05s}.statsGrid>:nth-child(2){animation-delay:.1s}.statCard{background-color:var(--color-white);border:1px solid var(--border-gray-light);border-radius:var(--radius-lg);padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.statCard:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-primary),rgba(76,175,80,.5));opacity:0;transition:opacity .3s ease}.statCard:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001f;border-color:var(--color-primary)}.statCard:hover:before{opacity:1}.statCard.highlighted{background-color:var(--color-white);border:1.5px solid rgba(255,193,7,.5);box-shadow:0 4px 12px #ffc10733}.statCard.highlighted:before{background:linear-gradient(90deg,#fbbf24,#f59e0b);opacity:1}.statCard.highlighted:hover{box-shadow:0 8px 24px #ffc1074d;border-color:#fbbf24}.statContent{display:flex;align-items:flex-start;gap:12px;min-width:0;width:100%}.iconBox{width:44px;height:44px;min-width:44px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;background-color:#4caf5014;flex-shrink:0}.statCard.highlighted .iconBox{background-color:#ffc10726}.statIcon{font-size:1.5rem;color:var(--color-primary)}.statCard.highlighted .statIcon{color:#fbbf24}.statText{display:flex;flex-direction:column;gap:8px;min-width:0;flex:1}.statTitle{font-size:.8rem;font-weight:600;color:var(--color-gray);text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.statValue{font-size:1.5rem;font-weight:800;color:var(--color-gray-dark);line-height:1.1;white-space:nowrap}.statValue.rewardValue{color:#fbbf24;font-size:1.6rem;font-weight:800}.statsPaginationControls{display:flex;align-items:center;justify-content:center;gap:20px}.paginationBtn{width:40px;height:40px;border-radius:var(--radius-md);border:1px solid var(--border-gray-light);background-color:var(--color-white);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:var(--color-gray)}.paginationBtn:hover{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:scale(1.05)}.paginationBtn:active{transform:scale(.95)}.paginationIndicators{display:flex;gap:8px;align-items:center}.paginationDot{width:8px;height:8px;border-radius:50%;background-color:#d1d5db;cursor:pointer;transition:all .2s ease}.paginationDot:hover{background-color:var(--color-gray);transform:scale(1.2)}.paginationDot.active{background-color:var(--color-primary);width:24px;border-radius:4px}.activityTimeline{background-color:var(--color-white);padding:1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem}.activityTimeline .sectionTitle{text-align:center;font-size:1rem;font-weight:600;color:var(--color-primary-dark)}.contactInfoSection{background-color:var(--color-white);padding:1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.contactInfoSection h3{font-size:1rem;font-weight:600;color:var(--color-gray-dark);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}.contactGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.contactItem{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background-color:var(--color-gray-light);border-radius:var(--radius-md);transition:all .2s ease}.contactItem:hover{background-color:#4caf500d}.contactIcon{color:var(--color-primary);flex-shrink:0;margin-top:2px}.contactItem div{display:flex;flex-direction:column;gap:4px}.contactLabel{font-size:.75rem;font-weight:600;color:var(--color-gray);text-transform:uppercase;letter-spacing:.5px}.contactValue{font-size:.95rem;color:var(--color-gray-dark);font-weight:500}.activitySection{background-color:var(--color-white);padding:1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.activitySection h3{font-size:1rem;font-weight:600;color:var(--color-gray-dark);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}.activityList{display:flex;flex-direction:column;gap:.75rem}.activityItem{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background-color:var(--color-gray-light);border-radius:var(--radius-md)}.activityIcon{width:36px;height:36px;border-radius:var(--radius-md);background-color:#4caf5026;display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.activityItem.activity-tabung-sampah{border-left-color:#10b981}.activityIcon.activity-tabung-sampah{background-color:#10b98126;color:#10b981}.activityItem.activity-tukar-poin{border-left-color:#3b82f6}.activityIcon.activity-tukar-poin{background-color:#3b82f626;color:#3b82f6}.activityItem.activity-badge{border-left-color:#a855f7}.activityIcon.activity-badge{background-color:#a855f726;color:#a855f7}.activityItem.activity-tukar-produk{border-left-color:#f97316}.activityIcon.activity-tukar-produk{background-color:#f9731626;color:#f97316}.activityItem.activity-poin{border-left-color:#fbbf24}.activityIcon.activity-poin{background-color:#fbbf2426;color:#fbbf24}.activityItem.activity-default{border-left-color:#6b7280}.activityIcon.activity-default{background-color:#6b728026;color:#6b7280}.activityContent{flex:1;display:flex;flex-direction:column;gap:4px}.activityTitle{font-size:.95rem;font-weight:600;color:var(--color-gray-dark)}.activityDesc{font-size:.85rem;color:var(--color-gray)}.activityTime{font-size:.8rem;color:var(--color-gray);margin-top:4px}.timelineFilter{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.timelineFilter button{padding:6px 12px;font-size:.875rem;border:none;border-radius:var(--radius-sm);background-color:var(--color-gray-light);color:var(--color-gray-dark);cursor:pointer;transition:background-color .2s ease}.timelineFilter button:hover{background-color:var(--color-primary-light)}.timelineFilter button.active{background-color:var(--color-primary-dark);color:#fff}.timelineList{list-style:none;padding:0;display:flex;flex-direction:column;gap:.75rem}.timelineItem{display:flex;align-items:center;background-color:var(--color-gray-light);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.875rem;color:var(--color-gray-dark)}.timelineIcon{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-right:12px}.timelineContent{flex:1;display:flex;flex-direction:column;gap:4px}.timelineDesc{font-weight:500;color:var(--color-primary-dark)}.timelineDetail{font-size:.75rem;color:var(--color-gray)}.timelineIcon.penyetoran{background-color:var(--color-green-soft);color:#047857}.timelineIcon.penukaran{background-color:var(--color-yellow-soft);color:#b45309}.timelineIcon.partisipasi{background-color:var(--color-blue-soft);color:#0284c7}.timelineIcon.penyelesaian{background-color:var(--color-purple-soft);color:#7c3aed}.timelineIcon.badge{background-color:var(--color-red-soft);color:#db2777}@media screen and (max-width:768px){.userDataContainer{padding:1rem;gap:1rem}.statsGrid{grid-template-columns:repeat(2,1fr);gap:12px}.statCard{padding:16px;min-height:120px}.statValue{font-size:1.25rem}.statTitle{font-size:.8rem}.statIcon{font-size:18px}.statsPaginationControls{gap:12px}.paginationBtn{width:36px;height:36px}.activityTimeline{padding:1rem;box-shadow:none;border:1px solid var(--border-gray-light)}.timelineItem{font-size:.75rem;padding:.5rem .75rem}.timelineDesc{font-size:.75rem}.timelineDetail{font-size:.7rem}}@media screen and (max-width:480px){.userDataContainer{padding:.75rem;gap:.75rem}.statsGrid{grid-template-columns:repeat(2,1fr);gap:10px}.statCard{padding:14px;min-height:110px}.statValue{font-size:1.1rem}.statTitle{font-size:.75rem}.statIcon{font-size:16px}}@media screen and (max-width:360px){.userDataContainer{padding:.5rem;gap:.5rem}.statsGrid{grid-template-columns:repeat(2,1fr);gap:8px}.statCard{padding:12px;min-height:100px}.statValue{font-size:1rem}.statTitle{font-size:.7rem}.statIcon{font-size:14px}}*{box-sizing:border-box;font-family:Work Sans,sans-serif}a{text-decoration:none;color:inherit}html,body,#root{margin:0;padding:0;width:100%;height:100%;box-sizing:border-box;overflow-x:hidden}.bottom-nav-container,.floating-profil-btn{display:none}@media(max-width:1024px){.bottom-nav-container{display:block;position:fixed;bottom:0;left:0;right:0;z-index:1000;background:#fff;border-top:1px solid #e5e7eb;box-shadow:0 -2px 8px #0000001a}.bottom-nav-wrapper{display:flex;justify-content:space-around;align-items:center;max-width:100%;height:70px;padding:0 8px;gap:0}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;height:70px;background:none;border:none;cursor:pointer;color:#6b7280;transition:all .3s ease;padding:0 4px;gap:6px;position:relative}.bottom-nav-item:hover{background:#22c55e0d;color:#22c55e}.bottom-nav-item.active{color:#22c55e}.bottom-nav-item.active:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%);width:3px;height:3px;background:#22c55e;border-radius:50%}.bottom-nav-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;position:relative;color:inherit}.bottom-nav-icon svg{width:100%;height:100%;color:inherit}.bottom-nav-label{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70px;color:inherit}.floating-profil-btn{display:flex;position:fixed;bottom:calc(80px + env(safe-area-inset-bottom));right:16px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#16a34a,#22c55e);border:none;cursor:pointer;color:#fff;box-shadow:0 4px 12px #22c55e4d;transition:all .3s ease;z-index:999;align-items:center;justify-content:center;outline:none;-webkit-tap-highlight-color:transparent}.floating-profil-btn:hover{transform:translateY(-4px);box-shadow:0 6px 20px #22c55e66}.floating-profil-btn:active{transform:translateY(-2px)}.floating-profil-btn.active{background:linear-gradient(135deg,#15803d,#16a34a)}.floating-btn-icon{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#fff}.floating-btn-icon svg{width:28px;height:28px;color:inherit}}@media(max-width:640px){.bottom-nav-container{display:block;position:fixed;bottom:0;left:0;right:0;z-index:1000;background:#fff;border-top:1px solid #e5e7eb;box-shadow:0 -2px 8px #0000001a}.bottom-nav-wrapper{display:flex;justify-content:space-around;align-items:center;height:64px;padding:0 4px;gap:0;max-width:100%}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;height:64px;background:none;border:none;cursor:pointer;color:#9ca3af;transition:all .2s ease;padding:0 2px;gap:4px;position:relative;outline:none;-webkit-tap-highlight-color:transparent}.bottom-nav-item:active{background:#22c55e14}.bottom-nav-item:hover,.bottom-nav-item.active{color:#22c55e}.bottom-nav-item.active .bottom-nav-icon{transform:scale(1)}.bottom-nav-icon{width:26px;height:26px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease;color:inherit}.bottom-nav-icon svg{width:100%;height:100%;color:inherit}.bottom-nav-label{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:55px;color:inherit}.floating-profil-btn{display:flex;position:fixed;bottom:calc(74px + env(safe-area-inset-bottom));right:12px;width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,#16a34a,#22c55e);border:none;cursor:pointer;color:#fff;box-shadow:0 4px 12px #22c55e4d;transition:all .2s ease;z-index:999;align-items:center;justify-content:center;outline:none;-webkit-tap-highlight-color:transparent}.floating-profil-btn:hover{transform:translateY(-3px);box-shadow:0 6px 16px #22c55e59}.floating-profil-btn:active{transform:translateY(-1px)}.floating-profil-btn.active{background:linear-gradient(135deg,#15803d,#16a34a)}.floating-btn-icon{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#fff}.floating-btn-icon svg{width:26px;height:26px;color:inherit}}@media(max-width:480px){.bottom-nav-wrapper{height:60px;padding:0 2px}.bottom-nav-item{height:60px;gap:3px}.bottom-nav-icon{width:24px;height:24px}.bottom-nav-label{font-size:11px;max-width:50px}.floating-leaderboard-btn{display:flex;bottom:calc(70px + env(safe-area-inset-bottom));right:10px;width:52px;height:52px}.floating-btn-icon svg{width:24px;height:24px}}@supports (padding: max(0px)){@media(max-width:1024px){.bottom-nav-container{padding-bottom:max(0px,env(safe-area-inset-bottom))}.bottom-nav-wrapper{height:calc(70px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-item{height:70px}.floating-leaderboard-btn{bottom:calc(80px + env(safe-area-inset-bottom))}}@media(max-width:640px){.bottom-nav-container{padding-bottom:max(0px,env(safe-area-inset-bottom))}.bottom-nav-wrapper{height:calc(64px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-item{height:64px}.floating-leaderboard-btn{bottom:calc(74px + env(safe-area-inset-bottom))}}@media(max-width:480px){.bottom-nav-container{padding-bottom:max(0px,env(safe-area-inset-bottom))}.bottom-nav-wrapper{height:calc(60px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-item{height:60px}.floating-leaderboard-btn{bottom:calc(70px + env(safe-area-inset-bottom))}}}@media(prefers-color-scheme:dark){@media(max-width:1024px){.bottom-nav-container{background:#1f2937;border-top-color:#374151}.bottom-nav-item{color:#9ca3af}.bottom-nav-item:hover{background:#22c55e1a}.bottom-nav-item.active{color:#4ade80}}}.bottom-nav-item{font-family:inherit}.bottom-nav-item:focus-visible{outline:2px solid #22c55e;outline-offset:-2px}@media(prefers-reduced-motion:reduce){.bottom-nav-item{transition:none}.bottom-nav-item.active .bottom-nav-icon{transform:none}}@media(max-width:1024px){body{padding-bottom:70px}}@media(max-width:640px){body{padding-bottom:64px}}@media(max-width:480px){body{padding-bottom:60px}}.offline-banner{position:fixed;top:0;left:0;right:0;z-index:9999;padding:12px 20px;display:flex;align-items:center;justify-content:center;gap:12px;font-size:14px;font-weight:500;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.offline-banner.offline{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#991b1b;border-bottom:2px solid #fca5a5}.offline-banner.online{background:linear-gradient(135deg,#f0fdf4,#dcfce7);color:#166534;border-bottom:2px solid #86efac}.offline-banner-content{display:flex;align-items:center;gap:8px}.offline-retry-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#dc2626;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.offline-retry-btn:hover{background:#b91c1c}.offline-dismiss-btn{padding:4px 8px;background:transparent;color:#166534;border:1px solid #166534;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s}.offline-dismiss-btn:hover{background:#166534;color:#fff}.cached-data-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:#fef3c7;color:#92400e;font-size:11px;font-weight:600;border-radius:12px;margin-left:8px}@media(max-width:600px){.offline-banner{padding:10px 16px;flex-wrap:wrap;gap:8px}.offline-banner-content{font-size:13px}.offline-retry-btn{width:100%;justify-content:center;padding:8px 12px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Work Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:linear-gradient(135deg,#f5f7fa,#e9ecef);min-height:100vh;display:flex;justify-content:center;align-items:center}html{scroll-behavior:smooth}.loginPageWrapper{width:100%;min-height:100vh;display:flex;justify-content:center;align-items:center;padding:2rem 1rem;position:relative}.loginPageWrapper:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#f5f7fa,#e9ecef);z-index:-1}.backButton{position:absolute;top:1.5rem;left:1.5rem;width:44px;height:44px;border:none;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #00000014;color:#333;z-index:10}.backButton:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f;background:#f8f9fa}.backButton:active{transform:translateY(0)}.loginContainer{background:#fff;padding:2.5rem 2rem;max-width:420px;width:100%;border-radius:1.5rem;box-shadow:0 10px 40px #00000014;position:relative;z-index:1}.loginHeader{text-align:center;margin-bottom:2rem}.logoIcon{width:80px;height:80px;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;color:#22c55e;overflow:hidden}.logoImage{width:100%;height:100%;object-fit:cover}.formTitle{font-size:1.75rem;font-weight:700;color:#1f2937;margin:0 0 .5rem;letter-spacing:-.5px}.formSubtitle{font-size:.95rem;color:#6b7280;font-weight:400;margin:0}.loginForm{display:flex;flex-direction:column;gap:1.25rem}.formGroup{display:flex;flex-direction:column;gap:.5rem}.inputLabel{font-size:.9rem;font-weight:600;color:#374151;display:block}.inputWrap{position:relative;display:flex;align-items:center;gap:.75rem;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;transition:all .18s ease;padding:.6rem .75rem;min-height:44px}.inputWrap:focus-within{border-color:#22c55e;box-shadow:0 0 0 3px #22c55e14}.inputWrap:hover{border-color:#d1d5db}.inputFieldWrapper{flex:1 1 auto;min-width:0;display:flex;align-items:center}.inputField{width:100%;min-width:0;border:none;outline:none;font-size:.95rem;background:transparent;color:#1f2937;padding:0;line-height:1.2;overflow:visible;word-break:break-word}.inputField::placeholder{color:#9ca3af;font-weight:400}.inputField:disabled{background:transparent;cursor:not-allowed;opacity:.7}.iconWrapper{display:flex;align-items:center;justify-content:center;flex:0 0 auto;width:28px;height:28px;color:#9ca3af;transition:color .18s ease}.inputWrap:focus-within .iconWrapper{color:#22c55e}.togglePassword{background:none;border:none;cursor:pointer;color:#9ca3af;display:flex;align-items:center;justify-content:center;padding:0;transition:color .18s ease;width:28px;height:28px;flex:0 0 auto}.togglePassword:hover{color:#22c55e}.inputWrap:focus-within .togglePassword{color:#22c55e}.errorAlert{background:#fee2e2;border:1px solid #fecaca;border-radius:.75rem;padding:.75rem 1rem;margin-top:-.5rem}.errorText{color:#dc2626;font-size:.9rem;margin:0;font-weight:500}.linksRow{display:flex;justify-content:space-between;gap:1rem;margin-top:.5rem}.forgotLink{font-size:.85rem;color:#22c55e;text-decoration:none;font-weight:500;transition:all .3s ease;flex:1;text-align:right}.forgotLink:first-child{text-align:left;color:#6b7280}.forgotLink:hover{text-decoration:underline;color:#16a34a}.loginBtn{width:100%;padding:.875rem;border:none;border-radius:.75rem;background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;letter-spacing:.5px;box-shadow:0 4px 12px #22c55e4d}.loginBtn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #22c55e66;background:linear-gradient(135deg,#15803d,#16a34a)}.loginBtn:active:not(:disabled){transform:translateY(0)}.loginBtn:disabled{opacity:.7;cursor:not-allowed}@media(max-width:768px){.loginContainer{padding:2rem 1.5rem;margin-top:2rem}.formTitle{font-size:1.5rem}.loginForm{gap:1rem}.inputWrap{padding:.6875rem;gap:.625rem}.inputField{font-size:.9rem}}@media(max-width:480px){.loginPageWrapper{padding:1.5rem 1rem}.backButton{top:1rem;left:1rem;width:40px;height:40px}.loginContainer{padding:1.75rem 1.25rem;border-radius:1.25rem;max-width:100%;margin-top:2.5rem}.loginHeader{margin-bottom:1.75rem}.logoIcon{width:56px;height:56px}.formTitle{font-size:1.35rem}.formSubtitle{font-size:.85rem}.formGroup{gap:.4rem}.inputLabel{font-size:.85rem}.inputWrap{padding:.625rem;gap:.5rem;border-radius:.625rem}.inputFieldWrapper{flex:1}.inputField{font-size:.9rem}.iconWrapper,.togglePassword{width:18px;height:18px}.loginBtn{padding:.8rem;font-size:.95rem}.linksRow{gap:.5rem}.forgotLink{font-size:.8rem}}@media(max-width:360px){.loginContainer{padding:1.5rem 1rem}.formTitle{font-size:1.2rem}.formSubtitle{font-size:.8rem}.inputWrap{padding:.5625rem;gap:.4375rem}.inputField{font-size:.85rem}.iconWrapper,.togglePassword{width:16px;height:16px}.loginBtn{padding:.75rem;font-size:.9rem}}.registerLinkContainer{display:flex;align-items:center;justify-content:center;gap:.375rem;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid #e5e7eb}.registerText{color:#6b7280;font-size:.9rem;font-weight:400}.registerLink{color:#22c55e;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .2s ease}.registerLink:hover{color:#16a34a;text-decoration:underline}@media(max-width:480px){.registerLinkContainer{flex-direction:column;gap:.25rem}.registerText,.registerLink{font-size:.85rem}}
