.profile-page {
  position: relative;
  min-height: 100vh;
  padding: 24px;
}

.profile-page.hidden { display: none; }

.profile-wrap {
  max-width: 1400px;
  margin: 0 auto;
}

.profile-topbar {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 18px;
}

.profile-back-btn {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  color: #fff;
  padding: 10px 14px;
  border-radius: 12px;
  cursor: pointer;
  transition: .2s;
}

.profile-back-btn:hover {
  background: rgba(255,255,255,0.1);
}

.profile-topbar-title {
  font-size: 20px;
  font-weight: 800;
  opacity: .95;
}

.profile-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-bottom: 18px;
}

.profile-card {
  padding: 20px;
  border-radius: 18px;
}

.profile-header {
  display: flex;
  gap: 14px;
  align-items: center;
  margin-bottom: 16px;
}

.profile-avatar {
  width: 60px;
  height: 60px;
  border-radius: 14px;
  object-fit: cover;
}

.profile-name {
  font-size: 26px;
  font-weight: 900;
  letter-spacing: .2px;
}

.profile-sub { margin-top: 4px; opacity: .75; }

.profile-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 12px;
}

.ps-item {
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
}

.ps-label { font-size: 12px; opacity: .7; }
.ps-val { font-size: 18px; font-weight: 800; margin-top: 6px; }

.profile-complain-btn {
  margin-top: 14px;
  background: transparent;
  border: none;
  color: #ff5b5b;
  font-weight: 700;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  opacity: .95;
}

.profile-block-title {
  font-size: 22px;
  font-weight: 900;
  margin-bottom: 14px;
}

.profile-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.pcard {
  position: relative;
  padding: 14px;
  border-radius: 16px;
  background: rgba(255,255,255,0.035);
  border: 1px solid rgba(255,255,255,0.06);
  overflow: hidden;
  min-height: 92px;
}

.pcard-val { font-size: 22px; font-weight: 900; }
.pcard-mult { color: #00ff86; font-size: 14px; font-weight: 800; margin-left: 6px; }
.pcard-title { margin-top: 6px; opacity: .75; font-size: 14px; }

.pcard-img {
  position: absolute;
  right: 12px;
  top: 14px;
  width: 52px;
  height: 52px;
  object-fit: contain;
  opacity: .95;
}

.profile-section { margin-bottom: 18px; padding: 20px; border-radius: 18px; }
.profile-section-title { font-size: 24px; font-weight: 900; display:flex; justify-content:space-between; gap: 16px; }

.profile-ach-grid {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 12px;
}

.profile-more-btn {
  margin-top: 14px;
  padding: 12px 16px;
  border-radius: 14px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  color: #fff;
  cursor: pointer;
  font-weight: 800;
}

/* адаптив */
@media (max-width: 1100px) {
  .profile-grid { grid-template-columns: 1fr; }
  .profile-stats { grid-template-columns: repeat(2, 1fr); }
  .profile-ach-grid { grid-template-columns: repeat(4, 1fr); }
  .profile-cards-grid { grid-template-columns: repeat(2, 1fr); }
}

/* =========================================
   PLAYER PROFILE PAGE (Variant B)
   ========================================= */

.pp-page {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 14px 6px 30px;
}

/* общий стиль карточек */

.pp-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 15% 15%, rgba(255,255,255,0.08), transparent 55%),
    radial-gradient(circle at 85% 85%, rgba(0,255,200,0.06), transparent 65%),
    linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0));
  opacity: 0.9;
}

.pp-card > * {
  position: relative;
  z-index: 2;
}

/* заголовки секций */
.pp-card-title {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: 0.2px;
  color: #fff;
  display: flex;
  align-items: center;
  gap: 10px;
}

.pp-info {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  opacity: 0.8;
}

/* =========================================
   TOP GRID
   ========================================= */

.pp-top-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 18px;
}

/* =========================================
   PLAYER CARD
   ========================================= */

.pp-player-card {
  padding: 18px 18px 14px;
}

.pp-player-head {
  display: flex;
  gap: 14px;
  align-items: center;
  margin-bottom: 18px;
}



.pp-player-meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}


.pp-status {
  font-size: 14px;
  opacity: 0.75;
  color: rgba(255,255,255,0.85);
}

/* министаты */
.pp-mini-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px 26px;
  margin-top: 10px;
}

.pp-mini {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.pp-mini-label {
  font-size: 13px;
  color: rgba(255,255,255,0.7);
}

.pp-mini-value {
  font-size: 18px;
  font-weight: 800;
  color: #fff;
}

/* кнопка жалобы */
.pp-report {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 18px;
  font-size: 14px;
  color: #ff4e4e;
  cursor: pointer;
  width: fit-content;
  user-select: none;
  opacity: 0.9;
}

.pp-report:hover {
  opacity: 1;
  transform: translateY(-1px);
}

.pp-report-icon {
  display: inline-flex;
  width: 22px;
  height: 22px;
  border-radius: 8px;
  align-items: center;
  justify-content: center;
  background: rgba(255, 78, 78, 0.18);
  border: 1px solid rgba(255,78,78,0.25);
  font-weight: 900;
}

/* =========================================
   RESOURCES CARD
   ========================================= */

.pp-resources-card {
  padding: 18px;
}

.pp-grid-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
}

/* общая карточка предмета */
.pp-item-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.04);
  border-radius: 14px;
  padding: 12px 12px 14px;
  min-height: 92px;
  position: relative;
  overflow: hidden;
  transition: 0.18s ease;
}

.pp-item-card:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.045);
}

.pp-item-top {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 10px;
}

.pp-item-val {
  font-size: 18px;
  font-weight: 900;
  color: #fff;
}

.pp-item-mul {
  font-size: 12px;
  font-weight: 800;
  color: #10ffb4;
  opacity: 0.85;
}

.pp-item-img {
  margin-left: auto;
  width: 56px;
  height: 56px;
  object-fit: contain;
  filter: drop-shadow(0 12px 14px rgba(0,0,0,0.45));
}

.pp-item-title {
  font-size: 14px;
  color: rgba(255,255,255,0.78);
  line-height: 1.1;
}

/* =========================================
   ACHIEVEMENTS
   ========================================= */

.pp-achievements {
  padding: 18px;
}

.pp-ach-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}

.pp-ach-progress {
  font-size: 13px;
  font-weight: 700;
  color: rgba(255,80,80,0.95);
}

.pp-ach-grid {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 12px;
}

.pp-ach-item {
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.035);
  border-radius: 12px;
  padding: 14px 10px;
  min-height: 80px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
  justify-content: center;
  text-align: center;
  transition: 0.2s ease;
}

.pp-ach-item:hover {
  transform: translateY(-2px);
  background: rgba(255,255,255,0.04);
}

.pp-ach-icon {
  font-size: 20px;
  opacity: 0.9;
}

.pp-ach-title {
  font-size: 12px;
  color: rgba(255,255,255,0.70);
  line-height: 1.2;
}

.pp-ach-item.is-locked {
  opacity: 0.35;
  filter: grayscale(1);
}

/* =========================================
   SHOW MORE BUTTON
   ========================================= */

.pp-more-btn {
  margin-top: 14px;
  width: 220px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
  color: #fff;
  font-weight: 800;
  letter-spacing: 0.4px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: 0.18s ease;
}

.pp-more-btn:hover {
  background: rgba(255,255,255,0.055);
  transform: translateY(-1px);
}

.pp-more-arrow {
  font-size: 14px;
  opacity: 0.9;
}

/* =========================================
   QUICK ROW (small cards)
   ========================================= */

.pp-quick-row {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 14px;
}

.pp-small-card {
  background: rgba(40, 18, 60, 0.55);
  border: 1px solid rgba(255,255,255,0.04);
  border-radius: 14px;
  padding: 12px;
  overflow: hidden;
  transition: 0.18s ease;
}

.pp-small-card:hover {
  transform: translateY(-2px);
  background: rgba(50, 22, 70, 0.55);
}

.pp-small-top {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 8px;
}

.pp-small-val {
  font-size: 18px;
  font-weight: 900;
  color: #fff;
}

.pp-small-img {
  margin-left: auto;
  width: 56px;
  height: 56px;
  object-fit: contain;
  filter: drop-shadow(0 12px 14px rgba(0,0,0,0.45));
}

.pp-small-title {
  font-size: 13px;
  color: rgba(255,255,255,0.72);
}

/* =========================================
   SECTIONS GRID
   ========================================= */

.pp-section {
  padding: 18px;
}

.pp-section-head {
  margin-bottom: 14px;
}

.pp-section-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 14px;
}

/* half sections (cards+medicine etc) */
.pp-section.half .pp-section-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* =========================================
   PROFILE TOPBAR
   ========================================= */

.profile-topbar {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 14px;
}

.profile-topbar-title {
  font-size: 22px;
  font-weight: 900;
  color: #fff;
}

.profile-back-btn {
  background: rgba(255,255,255,0.035);
  border: 1px solid rgba(255,255,255,0.08);
  color: #fff;
  padding: 10px 14px;
  border-radius: 12px;
  font-weight: 800;
  cursor: pointer;
  transition: 0.18s ease;
}

.profile-back-btn:hover {
  background: rgba(255,255,255,0.06);
  transform: translateY(-1px);
}

/* =========================================
   LOADING / ERROR
   ========================================= */

.pp-loading {
  padding: 30px;
  text-align: center;
  font-size: 16px;
  color: rgba(255,255,255,0.75);
}

/* =========================================
   RESPONSIVE
   ========================================= */

@media (max-width: 1200px) {
  .pp-top-grid {
    grid-template-columns: 1fr;
  }

  .pp-ach-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }

  .pp-section-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .pp-quick-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .pp-mini-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }

  .pp-grid-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pp-ach-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .pp-section-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
  .pp-name {
    font-size: 26px;
  }

  .pp-avatar {
    width: 54px;
    height: 54px;
  }

  .pp-card-title {
    font-size: 18px;
  }

  .pp-section-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pp-section.half .pp-section-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pp-more-btn {
    width: 100%;
  }
}

/* ======================================================
   PLAYER PROFILE PAGE (Neon Lime Theme)
   ====================================================== */

:root{
  --pp-bg: rgba(8, 12, 10, 0.68);
  --pp-card: rgba(12, 20, 16, 0.72);
  --pp-border: rgba(0, 255, 160, 0.14);
  --pp-border-2: rgba(180, 255, 80, 0.25);

  --pp-glow: rgba(0, 255, 160, 0.25);
  --pp-glow-2: rgba(180, 255, 80, 0.24);

  --pp-text: rgba(255,255,255,0.92);
  --pp-muted: rgba(255,255,255,0.65);

  --pp-lime: #baff3a;
  --pp-green: #00ffa0;

  --pp-red: #ff3b3b;
}

/* ===== базовая страница ===== */

.pp-page{
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 14px 6px 30px;
}

/* ===== общие карточки ===== */
.pp-card{
  background: var(--pp-card);
  border: 1px solid var(--pp-border);
  border-radius: 20px;
  box-shadow:
    0 10px 40px rgba(0,0,0,0.55),
    0 0 30px rgba(0,255,160,0.08);
  padding: 18px;
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(14px);
}

/* glow layer */
.pp-card::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 12% 18%, rgba(179, 255, 80, 0.021), transparent 52%),
    radial-gradient(circle at 90% 85%, rgba(0, 255, 162, 0.014), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,0.03), rgba(0,0,0,0));
  opacity: 0.95;
}

.pp-card > *{
  position: relative;
  z-index: 2;
}

/* ===== заголовки ===== */
.pp-card-title{
  font-size: 22px;
  font-weight: 900;
  letter-spacing: 0.3px;
  color: var(--pp-text);
  display:flex;
  align-items:center;
  gap:10px;
  text-shadow: 0 0 10px rgba(0,255,160,0.18);
}

.pp-info{
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(0,255,160,0.10);
  border: 1px solid rgba(0,255,160,0.25);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size: 12px;
  font-weight: 900;
  color: var(--pp-green);
  box-shadow: 0 0 10px rgba(0,255,160,0.25);
}

/* ======================================================
   TOP GRID
   ====================================================== */

.pp-top-grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 18px;
}

/* ======================================================
   PLAYER CARD
   ====================================================== */

.pp-player-card{
  padding: 18px 18px 14px;
}

/* header block */
.pp-player-head{
  display:flex;
  gap:16px;
  align-items:center;
  margin-bottom: 18px;
}


.pp-player-meta{
  display:flex;
  flex-direction:column;
  gap: 4px;
  min-width:0;
}


.pp-status{
  font-size: 14px;
  color: var(--pp-muted);
}

.pp-steamid{
  font-size: 12px;
  color: rgba(255,255,255,0.45);
  font-weight: 700;
}

/* ===== Steam Button ===== */
.pp-steam-btn{
  margin-top: 10px;
  padding: 10px 14px;
  border-radius: 14px;
  background: rgba(0,255,160,0.10);
  border: 1px solid rgba(0,255,160,0.28);
  color: #fff;
  font-weight: 900;
  cursor:pointer;
  transition: .18s ease;
  box-shadow:
    0 0 18px rgba(0,255,160,0.20);
}

.pp-steam-btn:hover{
  transform: translateY(-2px);
  background: rgba(0,255,160,0.16);
  box-shadow:
    0 0 26px rgba(0,255,160,0.32);
}

/* ======================================================
   MINI STATS
   ====================================================== */

.pp-mini-stats{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 14px 22px;
  margin-top: 10px;
}

.pp-mini{
  display:flex;
  flex-direction:column;
  gap: 6px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(0,255,160,0.10);
  transition: 0.18s;
}

.pp-mini:hover{
  transform: translateY(-2px);
  border-color: rgba(186,255,58,0.28);
  box-shadow: 0 0 16px rgba(0,255,160,0.14);
}

.pp-mini-label{
  font-size: 12px;
  color: rgba(255,255,255,0.65);
  font-weight: 700;
}

.pp-mini-value{
  font-size: 18px;
  font-weight: 900;
  color: #fff;
}

.pp-mini-ico{
  font-size: 16px;
  opacity: 0.85;
  margin-right: 6px;
}

/* ======================================================
   BADGES
   ====================================================== */

.pp-badges{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
  margin-top: 14px;
}

.pp-badge{
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  background: rgba(0,255,160,0.12);
  border: 1px solid rgba(0,255,160,0.25);
  color: #fff;
  box-shadow: 0 0 12px rgba(0,255,160,0.18);
}

.pp-badge.badge-pvp{
  background: rgba(186,255,58,0.12);
  border-color: rgba(186,255,58,0.32);
  box-shadow: 0 0 12px rgba(186,255,58,0.18);
}

.pp-badge.badge-raider{
  background: rgba(255, 70, 70, 0.12);
  border-color: rgba(255,70,70,0.32);
  box-shadow: 0 0 12px rgba(255,70,70,0.18);
}

/* ======================================================
   RESOURCES / ACTIVITY
   ====================================================== */

.pp-grid-cards{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
  margin-top: 16px;
}

.pp-item-card{
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(0,255,160,0.09);
  border-radius: 16px;
  padding: 12px 12px 14px;
  min-height: 92px;
  position: relative;
  overflow:hidden;
  transition: 0.18s ease;
}

.pp-item-card:hover{
  transform: translateY(-3px);
  border-color: rgba(186,255,58,0.25);
  background: rgba(255,255,255,0.04);
  box-shadow: 0 0 18px rgba(0,255,160,0.14);
}

.pp-item-top{
  display:flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 10px;
}

.pp-item-val{
  font-size: 20px;
  font-weight: 1000;
  color:#fff;
}

.pp-item-mul{
  font-size: 12px;
  font-weight: 900;
  color: var(--pp-lime);
  opacity: 0.9;
}

.pp-item-img{
  margin-left:auto;
  width: 56px;
  height: 56px;
  object-fit: contain;
  filter: drop-shadow(0 0 18px rgba(0,255,160,0.18));
  opacity: 0.95;
}

.pp-item-title{
  font-size: 13px;
  color: rgba(255,255,255,0.74);
  line-height:1.1;
}

/* ======================================================
   FULL STAT LIST
   ====================================================== */

.pp-stat-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 8px;
  margin-top: 10px;
}

.pp-stat-line{
  display:flex;
  justify-content:space-between;
  gap: 14px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(0,255,160,0.08);
  transition: 0.2s;
}

.pp-stat-line:hover{
  transform: translateY(-2px);
  border-color: rgba(186,255,58,0.25);
  box-shadow: 0 0 14px rgba(0,255,160,0.12);
}

.pp-stat-left{
  color: rgba(255,255,255,0.80);
  font-weight: 900;
  font-size: 13px;
  display:flex;
  align-items:center;
  gap: 8px;
}

.pp-stat-right{
  color: #fff;
  font-weight: 1000;
  font-size: 13px;
  text-shadow: 0 0 10px rgba(0,255,160,0.10);
}

/* ======================================================
   LOADING / ERROR
   ====================================================== */

.pp-loading{
  padding: 30px;
  text-align:center;
  font-size: 16px;
  color: rgba(255,255,255,0.75);
}

/* ======================================================
   RESPONSIVE
   ====================================================== */

@media (max-width: 1200px){
  .pp-top-grid{ grid-template-columns: 1fr; }
  .pp-grid-cards{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}

@media (max-width: 900px){
  .pp-mini-stats{
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 14px;
  }
}

@media (max-width: 520px){
  .pp-name{ font-size: 26px; }
  .pp-avatar{ width: 54px; height:54px; }
  .pp-card-title{ font-size: 18px; }
  .pp-grid-cards{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}

/* ======================================================
   PLAYER PROFILE — HERO UI (Neon Lime)
   ====================================================== */

.pp-page{
  display:flex;
  flex-direction:column;
  gap: 18px;
  padding: 16px 6px 28px;
}

/* HERO */
.pp-hero{
  display:flex;
  justify-content:space-between;
  gap: 18px;
  padding: 22px;
  border-radius: 26px;
  background: rgba(12, 18, 14, 0.74);
  border: 1px solid rgba(0,255,160,0.16);
  box-shadow:
    0 15px 45px rgba(0,0,0,0.55),
    0 0 30px rgba(0,255,160,0.10);
  backdrop-filter: blur(16px);
  position:relative;
  overflow:hidden;
}

.pp-hero::before{
  content:"";
  position:absolute;
  inset:-40px;
  background:
    radial-gradient(circle at 15% 22%, rgba(186,255,58,0.18), transparent 55%),
    radial-gradient(circle at 85% 75%, rgba(0,255,160,0.14), transparent 60%);
  pointer-events:none;
}

.pp-hero-left{
  display:flex;
  align-items:center;
  gap: 18px;
  z-index: 2;
}



.pp-hero-meta{
  display:flex;
  flex-direction:column;
  gap: 6px;
  min-width: 0;
}

.pp-name{
  font-size: 38px;
  font-weight: 1000;
  letter-spacing: 0.4px;
  color: #baff3a;
  text-shadow:
    0 0 14px rgba(186,255,58,0.25),
    0 0 22px rgba(0,255,160,0.18);
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}

.pp-sub{
  font-size: 14px;
  color: rgba(255,255,255,0.68);
}

.pp-steamid{
  font-size: 12px;
  color: rgba(255,255,255,0.45);
  font-weight: 700;
}

/* ACTIONS */
.pp-actions{
  display:flex;
  gap: 10px;
  margin-top: 10px;
  flex-wrap:wrap;
}

.pp-btn{
  padding: 10px 14px;
  border-radius: 16px;
  border: 1px solid rgba(0,255,160,0.25);
  background: rgba(0,255,160,0.10);
  color: #fff;
  font-weight: 900;
  cursor:pointer;
  transition:.18s ease;
  box-shadow: 0 0 18px rgba(0,255,160,0.16);
}

.pp-btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 0 26px rgba(0,255,160,0.30);
  background: rgba(0,255,160,0.14);
}

.pp-btn-main{
  border-color: rgba(186,255,58,0.30);
  background: rgba(186,255,58,0.12);
  box-shadow: 0 0 24px rgba(186,255,58,0.18);
}

.pp-btn-main:hover{
  background: rgba(186,255,58,0.16);
  box-shadow: 0 0 35px rgba(186,255,58,0.28);
}

.pp-btn-back{
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.10);
}

/* RIGHT BIG STATS */
.pp-hero-right{
  display:flex;
  gap: 14px;
  z-index: 2;
  align-items: center;
}

.pp-bigstat{
  min-width: 140px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(0,255,160,0.14);
  background: rgba(255,255,255,0.03);
  box-shadow: 0 0 18px rgba(0,255,160,0.10);
  text-align:center;
  transition:.18s ease;
}

.pp-bigstat:hover{
  transform: translateY(-3px);
  border-color: rgba(186,255,58,0.28);
  box-shadow: 0 0 26px rgba(186,255,58,0.16);
}

.pp-bigstat-label{
  font-size: 12px;
  color: rgba(255,255,255,0.65);
  font-weight: 800;
}

.pp-bigstat-value{
  font-size: 34px;
  font-weight: 1000;
  margin-top: 6px;
  color:#fff;
  text-shadow: 0 0 12px rgba(0,255,160,0.12);
}

/* MINI BLOCK card */
.pp-mini-block{
  padding: 16px;
}

.pp-mini-stats{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 14px;
}

.pp-mini{
  border-radius: 16px;
  padding: 12px;
  border: 1px solid rgba(0,255,160,0.10);
  background: rgba(255,255,255,0.02);
  transition:.18s ease;
}

.pp-mini:hover{
  transform: translateY(-2px);
  border-color: rgba(186,255,58,0.26);
  box-shadow: 0 0 18px rgba(0,255,160,0.12);
}

.pp-mini-label{
  font-size: 12px;
  color: rgba(255,255,255,0.65);
  font-weight: 800;
}

.pp-mini-value{
  margin-top: 6px;
  font-size: 18px;
  font-weight: 1000;
  color:#fff;
}

/* RESPONSIVE */
@media (max-width: 1200px){
  .pp-hero{
    flex-direction:column;
  }
  .pp-hero-right{
    width:100%;
    justify-content:space-between;
  }
}

@media (max-width: 740px){
  .pp-avatar-wrap{
    width: 96px;
    height: 96px;
  }
  .pp-avatar-lg{
    width: 96px;
    height: 96px;
    border-radius: 22px;
  }
  .pp-name{
    font-size: 28px;
  }
  .pp-mini-stats{
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
  .pp-bigstat{
    min-width: 0;
    width: 100%;
  }
  .pp-hero-right{
    flex-direction:column;
  }
}


/* ===============================================================*/
/* activity bars */
.pp-activity{
  margin-bottom: 14px;
  padding: 12px;
  border-radius: 14px;
  background: rgba(0,0,0,.25);
  border: 1px solid rgba(0,255,170,.12);
}
.pp-sub-title{
  font-weight: 700;
  margin-bottom: 10px;
  color: rgba(220,255,230,.9);
}
.pp-act-row{
  display:flex;
  align-items:center;
  gap:10px;
  margin: 7px 0;
}
.pp-act-label{
  width: 90px;
  font-size: 12px;
  color: rgba(220,255,230,.75);
}
.pp-act-bar{
  flex:1;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(0,255,170,.15);
  overflow:hidden;
}
.pp-act-fill{
  height:100%;
  border-radius:999px;
  background: linear-gradient(90deg, rgba(0,255,170,.95), rgba(190,255,0,.75));
  box-shadow: 0 0 14px rgba(0,255,170,.35);
}
.pp-act-num{
  width: 40px;
  text-align:right;
  font-weight: 700;
  font-size: 12px;
  color: rgba(220,255,230,.9);
}

/* places in tops */
.pp-place-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 12px;
  margin-top: 14px;
}
.pp-place-card{
  padding: 12px;
  border-radius: 16px;
  background: rgba(0,0,0,.23);
  border: 1px solid rgba(0,255,170,.15);
  text-align:center;
  transition:.2s ease;
}
.pp-place-card:hover{
  transform: translateY(-2px);
  border-color: rgba(0,255,170,.35);
  box-shadow: 0 0 18px rgba(0,255,170,.18);
}
.pp-place-icon{
  font-size: 20px;
  margin-bottom: 6px;
}
.pp-place-label{
  font-size: 12px;
  font-weight: 700;
  color: rgba(220,255,230,.8);
}
.pp-place-value{
  margin-top: 5px;
  font-size: 18px;
  font-weight: 900;
  color: rgba(190,255,0,.95);
  text-shadow: 0 0 12px rgba(0,255,170,.35);
}
.pp-place-none{
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,.4);
}
.pp-place-card.is-first{
  border: 1px solid rgba(190,255,0,.55);
  box-shadow: 0 0 25px rgba(190,255,0,.25);
}
