/* Phase 5: social + retention layer */
.phase5-panel{
  position:relative;
  z-index:3;
  width:min(1120px,calc(100% - 2rem));
  margin:1rem auto 0;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(300px,.72fr);
  gap:1rem;
}
.phase5-card{
  border-radius:28px;
  padding:1rem;
  background:rgba(255,255,255,.38);
  border:1px solid rgba(255,255,255,.38);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  box-shadow:0 20px 60px rgba(31,24,18,.12);
}
body.dark .phase5-card{
  background:rgba(255,255,255,.055);
  border-color:rgba(255,255,255,.09);
  box-shadow:0 20px 60px rgba(0,0,0,.28);
}
.phase5-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.8rem;
  margin-bottom:.85rem;
}
.phase5-head h3{
  margin:0;
  font-size:.95rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--text);
}
.phase5-pill{
  display:inline-flex;
  align-items:center;
  gap:.3rem;
  padding:.3rem .55rem;
  border-radius:999px;
  background:rgba(196,149,106,.14);
  border:1px solid rgba(196,149,106,.22);
  color:var(--accent-warm);
  font-size:.7rem;
  font-weight:950;
  white-space:nowrap;
}
.phase5-profile-card{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:.85rem;
  align-items:center;
}
.phase5-profile-card img{
  width:64px;
  height:64px;
  border-radius:50%;
  border:3px solid var(--accent-warm);
  background:var(--surface);
  box-shadow:0 12px 30px rgba(0,0,0,.16);
}
.phase5-profile-card h4{
  margin:0;
  font-size:1.25rem;
  letter-spacing:-.04em;
  color:var(--text);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.phase5-profile-card p{
  margin:.22rem 0 0;
  color:var(--text-dim);
  font-weight:750;
  font-size:.86rem;
}
.phase5-actions{
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.phase5-btn{
  border:none;
  border-radius:14px;
  min-height:38px;
  padding:.62rem .78rem;
  font-weight:950;
  cursor:pointer;
  background:rgba(255,255,255,.28);
  border:1px solid var(--border);
  color:var(--text);
}
body.dark .phase5-btn{background:rgba(255,255,255,.045)}
.phase5-btn.primary{
  background:linear-gradient(135deg,var(--accent-warm),#8c5b32);
  border:none;
  color:#150f08;
  box-shadow:0 14px 34px rgba(196,149,106,.2);
}
.phase5-btn:disabled{
  opacity:.55;
  cursor:not-allowed;
}
.phase5-stats-grid{
  grid-column:1/-1;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:.55rem;
  margin-top:.8rem;
}
.phase5-stat{
  border-radius:16px;
  padding:.7rem .5rem;
  text-align:center;
  background:rgba(255,255,255,.33);
  border:1px solid var(--border);
}
body.dark .phase5-stat{background:rgba(255,255,255,.045)}
.phase5-stat span{
  display:block;
  color:var(--text-dim);
  font-size:.62rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.phase5-stat strong{
  display:block;
  margin-top:.18rem;
  color:var(--text);
  font-size:1.05rem;
}
.phase5-achievements{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:.55rem;
}
.phase5-achievement{
  border-radius:18px;
  padding:.72rem;
  min-height:92px;
  background:rgba(255,255,255,.3);
  border:1px solid var(--border);
  opacity:.56;
  transition:opacity .18s ease, transform .18s ease, border-color .18s ease;
}
body.dark .phase5-achievement{background:rgba(255,255,255,.045)}
.phase5-achievement.unlocked{
  opacity:1;
  border-color:rgba(196,149,106,.48);
  background:linear-gradient(135deg,rgba(196,149,106,.16),rgba(255,255,255,.06));
}
.phase5-achievement:hover{transform:translateY(-2px)}
.phase5-achievement b{
  display:block;
  font-size:1.35rem;
  line-height:1;
  margin-bottom:.4rem;
}
.phase5-achievement strong{
  display:block;
  font-size:.82rem;
  color:var(--text);
}
.phase5-achievement span{
  display:block;
  margin-top:.18rem;
  color:var(--text-dim);
  font-size:.68rem;
  font-weight:750;
  line-height:1.25;
}
.phase5-history{
  display:grid;
  gap:.5rem;
  max-height:292px;
  overflow:auto;
  padding-right:.12rem;
}
.phase5-history::-webkit-scrollbar{width:6px}.phase5-history::-webkit-scrollbar-thumb{background:rgba(196,149,106,.45);border-radius:999px}
.phase5-history-row{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:.55rem;
  align-items:center;
  padding:.56rem;
  border-radius:16px;
  background:rgba(255,255,255,.3);
  border:1px solid var(--border);
}
body.dark .phase5-history-row{background:rgba(255,255,255,.045)}
.phase5-result-icon{
  width:32px;
  height:32px;
  border-radius:11px;
  display:grid;
  place-items:center;
  background:rgba(196,149,106,.15);
}
.phase5-history-row strong{
  display:block;
  color:var(--text);
  font-size:.82rem;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.phase5-history-row span{
  display:block;
  margin-top:.12rem;
  color:var(--text-dim);
  font-size:.66rem;
  font-weight:760;
}
.phase5-history-score{
  color:var(--accent-warm)!important;
  font-weight:950!important;
  white-space:nowrap;
}
.phase5-empty{
  padding:1rem;
  text-align:center;
  color:var(--text-dim);
  font-weight:750;
  border-radius:18px;
  background:rgba(255,255,255,.22);
  border:1px dashed var(--border);
}
.phase5-toast{
  position:fixed;
  left:50%;
  bottom:18px;
  transform:translateX(-50%) translateY(20px);
  z-index:2500;
  padding:.72rem .95rem;
  border-radius:18px;
  background:rgba(22,15,10,.88);
  color:#fff;
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 18px 52px rgba(0,0,0,.28);
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease, transform .2s ease;
  font-weight:850;
}
.phase5-toast.show{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}
@media(max-width:920px){
  .phase5-panel{grid-template-columns:1fr}
  .phase5-profile-card{grid-template-columns:auto minmax(0,1fr)}
  .phase5-actions{grid-column:1/-1;justify-content:flex-start}
}
@media(max-width:650px){
  .phase5-panel{width:calc(100% - 1rem);gap:.75rem}
  .phase5-card{border-radius:22px;padding:.82rem}
  .phase5-stats-grid{grid-template-columns:repeat(2,1fr)}
  .phase5-achievements{grid-template-columns:1fr 1fr}
  .phase5-profile-card img{width:54px;height:54px}
}
