.profile-hero{background:var(--bs-card-bg);border-radius:16px;margin-bottom:1.5rem;position:relative;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.12)}.profile-hero::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#22c55e,#28c76f,#00cfe8)}.profile-hero[data-rank=Apprentice]::before{background:linear-gradient(90deg,#22c55e,#28c76f)}.profile-hero[data-rank=Junior]::before{background:linear-gradient(90deg,#28c76f,#00cfe8)}.profile-hero[data-rank=Senior]::before{background:linear-gradient(90deg,#00cfe8,#7367f0)}.profile-hero[data-rank=Expert]::before{background:linear-gradient(90deg,#7367f0,#9e95f5)}.profile-hero[data-rank=Master]::before{background:linear-gradient(90deg,#9e95f5,#ff9f43)}.profile-hero[data-rank=Grandmaster]::before{background:linear-gradient(90deg,#ff9f43,#ea5455)}.profile-hero[data-rank=Legend]::before{background:linear-gradient(90deg,#fcd34d,#f59e0b,#ff6b00)}.profile-hero-content{display:flex;align-items:flex-start;gap:2rem;padding:2.5rem 2rem 2rem}.profile-avatar-section{position:relative;flex-shrink:0}.profile-avatar{width:140px;height:140px;border-radius:50%;box-shadow:0 8px 32px rgba(0,0,0,.2)}.profile-avatar-section.is-pro .profile-avatar{border:3px solid #f59e0b;box-shadow:0 0 0 2px #fcd34d,0 0 20px rgba(251,191,36,.3),0 8px 32px rgba(0,0,0,.2)}.profile-avatar-section.is-max .profile-avatar{border:3px solid #7c3aed;box-shadow:0 0 0 2px #a78bfa,0 0 20px rgba(124,58,237,.3),0 8px 32px rgba(0,0,0,.2)}.pro-badge-icon{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);padding:2px 12px;background:linear-gradient(135deg,#fcd34d,#f59e0b,#d97706);border-radius:10px;border:2px solid var(--bs-card-bg);z-index:10;box-shadow:0 2px 8px rgba(251,191,36,.5);font-size:.65rem;font-weight:700;color:#78350f;letter-spacing:.5px;text-transform:uppercase}.max-badge-icon{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);padding:2px 12px;background:linear-gradient(135deg,#a78bfa,#7c3aed,#6d28d9);border-radius:10px;border:2px solid var(--bs-card-bg);z-index:10;box-shadow:0 2px 8px rgba(124,58,237,.5);font-size:.65rem;font-weight:700;color:#fff;letter-spacing:.5px;text-transform:uppercase}.profile-avatar-overlay{position:absolute;inset:0;border-radius:50%;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .2s}.profile-avatar-overlay i{font-size:1.8rem;color:#fff}.profile-avatar-section.is-owner:hover .profile-avatar-overlay{opacity:1}.profile-avatar-section.is-owner .profile-avatar-overlay{opacity:0}.profile-avatar-section.is-owner{cursor:pointer}.profile-avatar-section.is-owner:hover .profile-avatar{filter:brightness(.8)}.profile-info{flex:1;min-width:0}.profile-name-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.profile-username{font-size:2rem;font-weight:700;margin:0;line-height:1}.profile-status-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .65rem;background:rgba(34,197,94,.15);border-radius:20px;font-size:.75rem;color:#22c55e;font-weight:500}.profile-status-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(34,197,94,.4)}50%{opacity:.8;box-shadow:0 0 0 6px rgba(34,197,94,0)}}.profile-rank-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .75rem;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2);border-radius:8px;font-size:.85rem;color:#22c55e;font-weight:600}.profile-hero-stats{display:flex;gap:1.5rem;margin-top:1rem;flex-wrap:wrap}.hero-stat{display:flex;align-items:center;gap:.4rem;font-size:.9rem;color:rgba(255,255,255,.7)}.hero-stat i{font-size:1.1rem;opacity:.6}.hero-stat-value{font-weight:700;color:rgba(255,255,255,.95);font-size:1.1rem}.hero-stat-label{font-size:.8rem;opacity:.6}.hero-stat-link{text-decoration:none;color:inherit;transition:opacity .2s}.hero-stat-link:hover{opacity:.8}.rank-change{font-size:.75rem;font-weight:700;margin-left:2px}.rank-up{color:#22c55e}.rank-down{color:#ea5455}.profile-momentum{display:flex;gap:.75rem;margin-top:.75rem;flex-wrap:wrap}.momentum-pill{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .65rem;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.15);border-radius:20px;font-size:.75rem;color:#22c55e;font-weight:600}.momentum-pill i{font-size:.85rem}a.momentum-pill{text-decoration:none;transition:background .2s,border-color .2s}a.momentum-pill:hover{background:rgba(34,197,94,.18);border-color:rgba(34,197,94,.3)}.profile-bio{margin:.4rem 0 0;font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.4;max-width:500px}.inline-editable{margin:.4rem 0 0;max-width:600px;width:100%}.inline-editable-display{display:inline-block;cursor:pointer;padding:.15rem .4rem;margin:-.15rem -.4rem;border-radius:6px;border:1px solid transparent;font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.4;transition:background .15s,border-color .15s}.inline-editable-display:hover{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1)}.inline-editable-display.is-empty{color:rgba(255,255,255,.2);font-style:italic;border:1px dashed rgba(255,255,255,.08)}.inline-editable-display.is-empty:hover{color:rgba(255,255,255,.35);border-color:rgba(255,255,255,.15);background:rgba(255,255,255,.03)}.inline-editable-compact{margin:0;max-width:none;display:inline}.inline-editable-compact .inline-editable-display{font-size:.8rem;padding:.1rem .3rem;margin:-.1rem -.3rem}.inline-edit-wrapper{display:flex;align-items:center;flex-wrap:wrap;gap:0;position:relative}.inline-edit-prefix{font-size:.75rem;color:rgba(255,255,255,.3);padding-right:.15rem;white-space:nowrap}.inline-edit-input{background:rgba(255,255,255,.06);border:1px solid rgba(14,165,233,.4);border-radius:6px;color:#fff;font-size:inherit;padding:.2rem .4rem;outline:0;min-width:120px;font-family:inherit;transition:border-color .2s;box-shadow:0 0 0 2px rgba(14,165,233,.1)}.inline-edit-input:focus{border-color:rgba(14,165,233,.6);box-shadow:0 0 0 3px rgba(14,165,233,.15)}textarea.inline-edit-input{resize:vertical;min-height:3rem;width:100%;min-width:400px}.inline-edit-char-counter{font-size:.7rem;color:rgba(255,255,255,.3);text-align:right;width:100%;margin-top:.25rem;transition:color .2s}.inline-edit-char-counter.near-limit{color:rgba(255,159,67,.6)}.inline-edit-char-counter.at-limit{color:rgba(234,84,85,.7)}.inline-edit-input.saving{border-color:rgba(14,165,233,.3);box-shadow:0 0 0 2px rgba(14,165,233,.08)}.inline-edit-input.saved{border-color:rgba(34,197,94,.5);box-shadow:0 0 0 2px rgba(34,197,94,.12)}.inline-edit-input.error{border-color:rgba(234,84,85,.5);box-shadow:0 0 0 2px rgba(234,84,85,.12);animation:inline-edit-shake .3s ease}@keyframes inline-edit-shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}.inline-edit-status{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;margin-left:.4rem;flex-shrink:0;opacity:0;transition:opacity .2s}.inline-edit-status.saving{opacity:1}.inline-edit-status.saving::after{content:'';width:14px;height:14px;border:2px solid rgba(14,165,233,.2);border-top-color:#0ea5e9;border-radius:50%;animation:inline-edit-spin .6s linear infinite}@keyframes inline-edit-spin{to{transform:rotate(360deg)}}.inline-edit-status.saved{opacity:1}.inline-edit-status.saved::after{content:'';width:16px;height:16px;background:#22c55e;border-radius:50%;mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 6L9 17l-5-5' stroke='white' stroke-width='3' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");mask-size:10px;mask-repeat:no-repeat;mask-position:center;-webkit-mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 6L9 17l-5-5' stroke='white' stroke-width='3' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");-webkit-mask-size:10px;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center;animation:inline-edit-pop .3s cubic-bezier(.34,1.56,.64,1)}@keyframes inline-edit-pop{0%{transform:scale(0)}100%{transform:scale(1)}}.inline-edit-status.error{opacity:1}.inline-edit-status.error::after{content:'';width:16px;height:16px;background:#ea5455;border-radius:50%;mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M18 6L6 18M6 6l12 12' stroke='white' stroke-width='3' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");mask-size:10px;mask-repeat:no-repeat;mask-position:center;-webkit-mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M18 6L6 18M6 6l12 12' stroke='white' stroke-width='3' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");-webkit-mask-size:10px;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center}.inline-edit-wrapper.has-ai-btn textarea.inline-edit-input{padding-right:44px}.ai-sparkle-btn{position:absolute;right:6px;top:6px;width:28px;height:28px;background:linear-gradient(135deg,#8b5cf6,#6366f1,#3b82f6);border:none;border-radius:7px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;line-height:1;transition:all .3s cubic-bezier(.4, 0, .2, 1);box-shadow:0 2px 8px rgba(99,102,241,.3);z-index:2;padding:0;color:#fff}.ai-sparkle-btn:hover{transform:scale(1.08);box-shadow:0 4px 16px rgba(99,102,241,.5)}.ai-sparkle-btn:disabled{cursor:default;opacity:.5;transform:none;box-shadow:none}.ai-generated .inline-edit-input,.ai-generating .inline-edit-input{resize:none}.ai-generating .inline-edit-input{border-color:transparent!important;color:transparent!important}.ai-generating .inline-edit-input::placeholder{color:transparent!important}.ai-generating .inline-edit-char-counter,.ai-generating .inline-edit-status{visibility:hidden}.ai-shimmer-overlay{position:absolute;top:0;left:0;right:0;height:0;border-radius:6px;overflow:hidden;pointer-events:none;z-index:1}.ai-shimmer-overlay::before{content:'';position:absolute;inset:0;border-radius:6px;padding:1.5px;background:linear-gradient(90deg,#8b5cf6,#3b82f6,#06b6d4,#8b5cf6);background-size:300% 100%;animation:ai-border-flow 2s linear infinite;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude}.ai-shimmer-lines{position:absolute;inset:10px 44px 10px 12px;display:flex;flex-direction:column;gap:10px}.ai-shimmer-line{height:14px;border-radius:4px;background:linear-gradient(90deg,rgba(99,102,241,.05) 25%,rgba(99,102,241,.12) 50%,rgba(99,102,241,.05) 75%);background-size:200% 100%;animation:ai-shimmer 1.5s ease-in-out infinite}.ai-shimmer-line:first-child{width:90%;animation-delay:0s}.ai-shimmer-line:nth-child(2){width:75%;animation-delay:.15s}.ai-shimmer-line:nth-child(3){width:45%;animation-delay:.3s}.ai-generating .ai-sparkle-btn{pointer-events:none;animation:ai-btn-pulse 1.2s ease-in-out infinite}.ai-generated .inline-edit-input{border-color:#22c55e!important;box-shadow:0 0 0 1px rgba(34,197,94,.1),0 0 20px rgba(34,197,94,.05);animation:ai-result-glow .6s ease-out}.ai-generated .ai-sparkle-btn{background:linear-gradient(135deg,#22c55e,#10b981);box-shadow:0 2px 8px rgba(34,197,94,.3);pointer-events:none}.has-ai-btn .inline-edit-char-counter{width:auto;margin-left:auto}.ai-hint{font-size:.7rem;flex:1;opacity:0;transition:opacity .3s}.ai-hint.visible{opacity:1}.ai-hint.success{color:#22c55e}.ai-hint.error{color:#ea5455}@keyframes ai-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}@keyframes ai-border-flow{0%{background-position:0 50%}100%{background-position:300% 50%}}@keyframes ai-btn-pulse{0%,100%{opacity:1;box-shadow:0 2px 8px rgba(99,102,241,.3)}50%{opacity:.6;box-shadow:0 2px 16px rgba(99,102,241,.6)}}@keyframes ai-result-glow{0%{box-shadow:0 0 0 3px rgba(99,102,241,.3),0 0 30px rgba(99,102,241,.15);border-color:#6366f1}100%{box-shadow:0 0 0 1px rgba(34,197,94,.1),0 0 20px rgba(34,197,94,.05);border-color:#22c55e}}.share-dropdown-wrapper{position:relative;margin-left:auto}.btn-share-profile{display:inline-flex;align-items:center;gap:.45rem;padding:.45rem 1.1rem;background:linear-gradient(135deg,#00cfe8,#0ea5e9);border:none;border-radius:10px;color:#fff;font-size:.82rem;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 10px rgba(14,165,233,.3)}.btn-share-profile:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(14,165,233,.5)}.share-dropdown{display:none;position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--bs-modal-bg);border:1px solid rgba(255,255,255,.12);border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.5);min-width:180px;z-index:100;overflow:hidden}.share-dropdown.show{display:block}.share-option{display:flex;align-items:center;gap:.6rem;padding:.6rem 1rem;font-size:.85rem;color:rgba(255,255,255,.7);text-decoration:none;border:none;background:0 0;width:100%;cursor:pointer;transition:background .15s}.share-option:hover{background:rgba(255,255,255,.06);color:#fff}.share-option i{font-size:1.1rem;width:20px;text-align:center}.profile-meta{display:flex;gap:1.25rem;margin-top:.75rem;flex-wrap:wrap}.profile-meta-item{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;color:rgba(255,255,255,.5)}.profile-meta-item i{font-size:.9rem}.profile-meta-link{color:rgba(255,255,255,.5);text-decoration:none}.profile-meta-link:hover{color:#22c55e}.discord-copy{cursor:pointer}.discord-copy-icon{font-size:.75em;opacity:0;margin-left:2px;transition:opacity .15s ease}.discord-copy:hover .discord-copy-icon{opacity:.6}.discord-copy.copied .discord-copy-icon{color:#22c55e;opacity:1}.discord-copy.copied .profile-meta-link{color:#22c55e}.complete-profile-banner{display:flex;align-items:center;gap:1.25rem;background:linear-gradient(135deg,rgba(14,165,233,.08),rgba(0,207,232,.06));border:1px solid rgba(14,165,233,.2);border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.complete-profile-icon{width:44px;height:44px;border-radius:50%;background:rgba(14,165,233,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}.complete-profile-icon i{font-size:1.4rem;color:#0ea5e9}.complete-profile-text{flex:1;min-width:200px}.complete-profile-text strong{display:block;font-size:.95rem;margin-bottom:.15rem}.complete-profile-text span{font-size:.8rem;color:rgba(255,255,255,.5)}.complete-profile-items{display:flex;gap:.75rem;flex-wrap:wrap}.complete-profile-item{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;color:rgba(255,255,255,.35)}.complete-profile-item i{font-size:1rem}.complete-profile-item.done{color:#22c55e}.profile-incomplete-field .inline-editable-display.is-empty{color:rgba(14,165,233,.6);border-color:rgba(14,165,233,.25);background:rgba(14,165,233,.05);animation:incomplete-pulse 3s ease-in-out infinite}@keyframes incomplete-pulse{0%,100%{border-color:rgba(14,165,233,.25)}50%{border-color:rgba(14,165,233,.45)}}.highlight-attention .inline-editable-display.is-empty{animation:attention-flash .5s ease-in-out 3;color:rgba(14,165,233,.9)!important;border-color:rgba(14,165,233,.6)!important;background:rgba(14,165,233,.12)!important}@keyframes attention-flash{0%,100%{box-shadow:0 0 0 0 rgba(14,165,233,0)}50%{box-shadow:0 0 0 4px rgba(14,165,233,.25)}}.certificate-banner{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,rgba(34,197,94,.08),rgba(0,207,232,.08));border:1px solid rgba(34,197,94,.15);border-radius:12px;padding:1rem 1.5rem;margin-bottom:1.5rem;gap:1rem}.certificate-banner-content{display:flex;align-items:center;gap:.75rem;font-weight:600;font-size:.9rem}.certificate-banner-content i{font-size:1.4rem;color:#22c55e}.certificate-banner-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1.4rem;background:linear-gradient(135deg,#fcd34d,#f59e0b);color:#78350f;border-radius:10px;font-size:.85rem;font-weight:700;text-decoration:none;white-space:nowrap;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 12px rgba(245,158,11,.3)}.certificate-banner-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(245,158,11,.45);color:#78350f}.profile-section{background:var(--bs-card-bg);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 12px rgba(0,0,0,.08)}.section-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.section-title{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;margin:0 0 1rem}.section-title i{color:#22c55e;font-size:1.2rem}.section-header-row .section-title{margin-bottom:0}.section-subtitle{font-size:.85rem;color:rgba(255,255,255,.5)}.heatmap-container{overflow-x:auto;padding-bottom:.5rem}.heatmap-months{display:flex;margin-bottom:4px;padding-left:30px}.heatmap-month-label{font-size:.65rem;color:rgba(255,255,255,.4);text-align:center}.heatmap-grid{display:flex;gap:3px;width:100%}.heatmap-week{display:flex;flex-direction:column;gap:3px;flex:1}.heatmap-cell{aspect-ratio:1;width:100%;border-radius:2px;transition:transform .15s}.heatmap-cell:hover{transform:scale(1.4)}.heatmap-cell.level-0{background:rgba(255,255,255,.06)}.heatmap-cell.level-visit{background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.12)}.heatmap-cell.level-1{background:#0e4429}.heatmap-cell.level-2{background:#006d32}.heatmap-cell.level-3{background:#26a641}.heatmap-cell.level-4{background:#39d353}.heatmap-legend{display:flex;align-items:center;gap:4px;margin-top:.75rem;justify-content:flex-end}.heatmap-legend .heatmap-cell{width:10px;height:10px}.heatmap-legend-label{font-size:.7rem;color:rgba(255,255,255,.4);margin:0 2px}.heatmap-tooltip{position:fixed;background:rgba(0,0,0,.9);color:#fff;padding:.35rem .6rem;border-radius:6px;font-size:.7rem;pointer-events:none;z-index:1000;white-space:nowrap;box-shadow:0 2px 8px rgba(0,0,0,.3)}.rank-progress-card{padding:.25rem 0}.rank-progress-labels{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.rank-current .rank-name{font-weight:700;font-size:1rem;color:#22c55e}.rank-next{text-align:right}.rank-next-label{font-size:.75rem;color:rgba(255,255,255,.4);margin-right:.35rem}.rank-next .rank-name{font-weight:600;font-size:.9rem;color:rgba(255,255,255,.6)}.rank-max .rank-name{color:#fcd34d;font-weight:700}.rank-progress-bar-wrapper{height:10px;background:rgba(255,255,255,.06);border-radius:8px;overflow:hidden}.rank-progress-bar{height:100%;border-radius:8px;background:linear-gradient(90deg,#22c55e,#28c76f,#00cfe8);transition:width 1s ease-out;min-width:2%}.rank-progress-text{text-align:center;margin-top:.5rem;font-size:.8rem;color:rgba(255,255,255,.5)}.badges-row{display:flex;gap:.75rem;flex-wrap:wrap}.badge-card{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.75rem 1rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:12px;min-width:80px;transition:transform .2s,box-shadow .2s}.badge-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.15);border-color:var(--badge-color,rgba(255,255,255,.15))}.badge-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--badge-color,#22c55e) 15%,transparent);border:1px solid color-mix(in srgb,var(--badge-color,#22c55e) 30%,transparent)}.badge-icon i{font-size:1.3rem;color:var(--badge-color,#22c55e)}.badge-name{font-size:.7rem;font-weight:600;color:rgba(255,255,255,.7);text-align:center;line-height:1.2}.skills-cloud{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{display:inline-block;padding:.3rem .75rem;background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.15);border-radius:20px;font-size:.8rem;color:rgba(255,255,255,.7);transition:background .2s,color .2s}.skill-tag:hover{background:rgba(34,197,94,.15);color:#22c55e}.profile-tabs{display:flex;gap:.25rem;background:var(--bs-card-bg);border-radius:12px 12px 0 0;padding:.4rem;margin-bottom:0;box-shadow:0 2px 12px rgba(0,0,0,.08);overflow-x:auto}.profile-tab{display:flex;align-items:center;gap:.4rem;padding:.6rem 1rem;border:none;background:0 0;color:rgba(255,255,255,.5);font-size:.85rem;font-weight:500;border-radius:8px;cursor:pointer;white-space:nowrap;transition:background .2s,color .2s}.profile-tab:hover{background:rgba(255,255,255,.05);color:rgba(255,255,255,.7)}.profile-tab.active{background:rgba(34,197,94,.12);color:#22c55e}.profile-tab i{font-size:1rem}.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 .4rem;border-radius:10px;background:rgba(255,255,255,.06);font-size:.7rem;font-weight:600}.profile-tab.active .tab-count{background:rgba(34,197,94,.2);color:#22c55e}.tab-content{display:none}.tab-content.active{display:block}.tab-content>.profile-section{border-radius:0 0 12px 12px;margin-top:0}.chapters-by-course{display:flex;flex-direction:column;gap:1.5rem}.course-group-header{display:flex;align-items:center;gap:.6rem;margin-bottom:.75rem}.course-group-name{font-size:1rem;font-weight:600;color:inherit;text-decoration:none}.course-group-name:hover{color:#22c55e}.chapters-list{display:flex;flex-direction:column;gap:.5rem;padding-left:.5rem;border-left:2px solid rgba(34,197,94,.15)}.chapter-row{display:flex;align-items:center;gap:.75rem;padding:.4rem .75rem}.chapter-marker{width:8px;height:8px;border-radius:50%;background:#22c55e;flex-shrink:0}.chapter-info{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0;flex-wrap:wrap}.chapter-title{font-size:.85rem;font-weight:500}.chapter-meta-inline{display:flex;align-items:center;gap:.3rem;font-size:.75rem;color:rgba(255,255,255,.4)}.chapter-meta-inline i{font-size:.8rem;color:#ff9f43}.chapter-date{margin-left:.5rem}.certificate-unlocked{text-align:center;padding:3rem 1rem}.certificate-icon-large{width:80px;height:80px;border-radius:50%;background:rgba(34,197,94,.12);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}.certificate-icon-large i{font-size:2.5rem;color:#22c55e}.certificate-unlocked h3{font-size:1.3rem;font-weight:600;margin-bottom:.5rem}.certificate-unlocked p{color:rgba(255,255,255,.5);margin-bottom:1.5rem}.cert-progress-bar{height:8px;background:rgba(255,255,255,.06);border-radius:4px;max-width:300px;margin:1rem auto;overflow:hidden}.cert-progress-fill{height:100%;background:linear-gradient(90deg,#22c55e,#00cfe8);border-radius:4px}.completions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.completion-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:1rem;transition:transform .2s,box-shadow .2s}.completion-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.12)}.completion-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.completion-lab-img{width:44px;height:44px;border-radius:10px;object-fit:cover;flex-shrink:0}.completion-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.completion-icon i{font-size:1.2rem;color:#fff}.completion-icon.difficulty-0{background:linear-gradient(135deg,#00cfe8,#0ea5e9)}.completion-icon.difficulty-1{background:linear-gradient(135deg,#22c55e,#28c76f)}.completion-icon.difficulty-2{background:linear-gradient(135deg,#00cfe8,#1ce7ff)}.completion-icon.difficulty-3{background:linear-gradient(135deg,#ff9f43,#ffb976)}.completion-icon.difficulty-4{background:linear-gradient(135deg,#ea5455,#f08182)}.completion-info{min-width:0}.completion-name{display:block;font-weight:600;font-size:.9rem;color:inherit;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.completion-name:hover{color:#22c55e}.completion-difficulty{font-size:.7rem;font-weight:500;padding:.1rem .5rem;border-radius:4px;display:inline-block;margin-top:.2rem}.badge-success{background:rgba(34,197,94,.15);color:#22c55e}.badge-info{background:rgba(0,207,232,.15);color:#00cfe8}.badge-warning{background:rgba(255,159,67,.15);color:#ff9f43}.badge-danger{background:rgba(234,84,85,.15);color:#ea5455}.badge-primary{background:rgba(14,165,233,.15);color:#7367f0}.completion-meta{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:rgba(255,255,255,.45)}.completion-xp{display:flex;align-items:center;gap:.25rem;color:#ff9f43;font-weight:600}.completion-xp i{font-size:.85rem}.activity-timeline{display:flex;flex-direction:column}.activity-timeline .timeline-item{display:flex;gap:1rem;padding:.75rem 0;border-left:none!important;padding-left:0}.timeline-dot{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.9rem}.timeline-flag .timeline-dot{background:rgba(34,197,94,.12);color:#22c55e}.timeline-chapter .timeline-dot{background:rgba(0,207,232,.12);color:#00cfe8}.timeline-blood .timeline-dot{background:rgba(234,84,85,.12);color:#ea5455}.timeline-content{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:.15rem}.timeline-text{font-size:.85rem;line-height:1.4}.timeline-text a{color:#22c55e;text-decoration:none}.timeline-text a:hover{text-decoration:underline}.timeline-xp{color:#22c55e;font-weight:600;font-size:.8rem;margin-left:.35rem}.timeline-time{font-size:.75rem;color:rgba(255,255,255,.35)}.empty-state-profile{text-align:center;padding:3rem 1rem}.empty-state-icon{width:64px;height:64px;border-radius:50%;background:rgba(34,197,94,.1);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.empty-state-icon i{font-size:1.8rem;color:#22c55e}.empty-state-title{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.empty-state-text{color:rgba(255,255,255,.5);font-size:.9rem;margin-bottom:1.5rem}.modern-card{background:var(--bs-card-bg);border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);margin-bottom:1.5rem}.modern-card-header{padding:1.5rem 1.5rem 0}.modern-card-body{padding:1.5rem}.section-header-title{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;margin:0}.profile-section{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}.profile-section.animate-visible{opacity:1;transform:translateY(0)}.modal-content.gravatar-modal-content{border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.08);background-color:#25293c!important;box-shadow:0 16px 48px rgba(0,0,0,.5)}.gravatar-modal-close{position:absolute;top:.85rem;right:.85rem;z-index:2;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;padding:0;border:0;border-radius:50%;background:rgba(255,255,255,.06);color:#d1d5db;font-size:1.05rem;line-height:1;cursor:pointer;transition:background .15s,color .15s,transform .15s}.gravatar-modal-close:hover{background:rgba(255,255,255,.16);color:#fff;transform:scale(1.08)}.gravatar-modal-close:focus-visible{outline:2px solid rgba(34,197,94,.6);outline-offset:2px}.gravatar-modal-body{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2.5rem 2rem 2rem}.gravatar-modal-avatar-wrapper{position:relative;margin-bottom:1.5rem;cursor:pointer}.gravatar-modal-avatar{width:120px;height:120px;border-radius:50%;border:3px solid rgba(255,255,255,.1);box-shadow:0 8px 32px rgba(0,0,0,.3)}.gravatar-modal-avatar-overlay{position:absolute;inset:0;border-radius:50%;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.gravatar-modal-avatar-wrapper:hover .gravatar-modal-avatar-overlay{opacity:1}.gravatar-modal-avatar-overlay i{font-size:2rem;color:#fff}.gravatar-modal-title{font-size:1.25rem;font-weight:700;margin:0 0 .35rem}.gravatar-modal-subtitle{font-size:.85rem;color:rgba(255,255,255,.45);margin:0 0 1.5rem}.gravatar-modal-steps{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:320px;margin-bottom:1.75rem;text-align:left}.gravatar-step{display:flex;align-items:flex-start;gap:.75rem;font-size:.85rem;color:rgba(255,255,255,.65);line-height:1.4}.gravatar-step a{color:#0ea5e9;text-decoration:none}.gravatar-step a:hover{text-decoration:underline}.gravatar-step strong{color:rgba(255,255,255,.85);word-break:break-all}.gravatar-step-num{width:26px;height:26px;border-radius:50%;background:rgba(14,165,233,.15);color:#0ea5e9;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.avatar-upload-preview{position:relative;margin-bottom:1.25rem}.avatar-upload-img{width:140px;height:140px;border-radius:50%;border:3px solid rgba(255,255,255,.1);box-shadow:0 8px 32px rgba(0,0,0,.3);object-fit:cover}.avatar-upload-spinner{position:absolute;inset:0;border-radius:50%;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;width:140px;height:140px}.avatar-spinner-ring{width:36px;height:36px;border:3px solid rgba(255,255,255,.2);border-top-color:#0ea5e9;border-radius:50%;animation:inline-edit-spin .7s linear infinite}.avatar-drop-zone{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1.5rem 2rem;border:2px dashed rgba(255,255,255,.12);border-radius:12px;cursor:pointer;transition:border-color .2s,background .2s;width:100%;max-width:320px;margin-bottom:1rem;position:relative}.avatar-drop-zone:hover{border-color:rgba(14,165,233,.4);background:rgba(14,165,233,.04)}.avatar-drop-zone.drag-active{border-color:#0ea5e9;background:rgba(14,165,233,.08)}.avatar-drop-zone i{font-size:2rem;color:rgba(255,255,255,.3)}.avatar-drop-zone:hover i{color:rgba(14,165,233,.6)}.avatar-drop-text{font-size:.85rem;color:rgba(255,255,255,.5)}.avatar-drop-hint{font-size:.7rem;color:rgba(255,255,255,.25)}.avatar-file-input{position:absolute;inset:0;opacity:0;cursor:pointer}.avatar-upload-error{color:#ea5455;font-size:.8rem;margin-bottom:.75rem;text-align:center}.avatar-remove-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .8rem;background:0 0;border:1px solid rgba(234,84,85,.2);border-radius:8px;color:rgba(234,84,85,.6);font-size:.78rem;cursor:pointer;transition:color .2s,border-color .2s,background .2s;margin-bottom:1rem}.avatar-remove-btn:hover{color:#ea5455;border-color:rgba(234,84,85,.4);background:rgba(234,84,85,.06)}.avatar-gravatar-link{font-size:.75rem}.avatar-gravatar-link a{color:rgba(255,255,255,.3);text-decoration:none;display:inline-flex;align-items:center;gap:.3rem;transition:color .2s}.avatar-gravatar-link a:hover{color:rgba(255,255,255,.5)}.gravatar-modal-cta{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 2rem;background:linear-gradient(135deg,#00cfe8,#0ea5e9);color:#fff;border-radius:12px;font-size:.95rem;font-weight:600;text-decoration:none;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 16px rgba(14,165,233,.3)}.gravatar-modal-cta:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(14,165,233,.45);color:#fff}@media (max-width:768px){.profile-hero-content{flex-direction:column;align-items:center;text-align:center;padding:2rem 1.25rem}.profile-avatar{width:110px;height:110px}.profile-name-row{justify-content:center}.profile-username{font-size:1.5rem}.profile-hero-stats{justify-content:center}.profile-meta{justify-content:center}.completions-grid{grid-template-columns:1fr}.badges-row{justify-content:center}.certificate-banner{flex-direction:column;text-align:center}}@media (max-width:480px){.profile-hero-stats{gap:1rem}.hero-stat-label{display:none}.profile-section{padding:1rem}}